O editor da Script House compartilhou vários códigos de função de criptografia e descriptografia ASP BASE64 com você antes. No entanto, existem alguns problemas no processo de uso real.
Código principal:
<% ' OPTION EXPLICITconst BASE_64_MAP_INIT = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"dim newlinedim Base64EncMap(63)dim Base64DecMap(127)'Função de inicialização PUBLIC SUB initCodecs()' Inicialize variáveis newline = "<P>" & chr(13) & chr(10)dim max, idxmax = len(BASE_64_MAP_INIT)for idx = 0 a max - 1Base64EncMap(idx) = mid(BASE_64_MAP_INIT, idx + 1, 1) próximo para idx = 0 ao máximo - 1Base64DecMap(ASC(Base64EncMap(idx))) = idxnextEND SUB'Base64 função de criptografia PUBLIC FUNCTION base64Encode(plain)if len(plain) = 0 thenbase64Encode = ""função de saídaend ifdim ret, ndx, by3, first, second, thirdby3 = ( len(simples) / 3) * 3ndx = 1do while ndx <= by3first = asc(mid(plain, ndx+0, 1))second = asc(mid(plain, ndx+1, 1))third = asc(mid(plain, ndx+2, 1)) ret = ret & Base64EncMap( ((primeiro / 4) AND 63 )ret = ret & Base64EncMap( ((primeiro * 16) AND 48) + ((segundo / 16) AND 15 ) )ret = ret & Base64EncMap( ((segundo * 4) AND 60) + ((terceiro / 64) AND 3 ) )ret = ret & Base64EncMap( terceiro AND 63)ndx = ndx + 3loopif by3 < len(plain) thenfirst = asc(mid(plain, ndx+0, 1))ret = ret & Base64EncMap( (primeiro / 4) AND 63 )if (len(plain) MOD 3 ) = 2 thensecond = asc(mid(plain, ndx+1, 1))ret = ret & Base64EncMap( ( (primeiro * 16) AND 48) + ((segundo / 16) AND 15 ))ret = ret & Base64EncMap( ((segundo * 4) AND 60) )elseret = ret & Base64EncMap( (primeiro * 16) AND 48)ret = ret '& "="end ifret = ret '& "="end ifbase64Encode = retEND FUNCTION'Função de descriptografia Base64 FUNÇÃO PÚBLICA base64Decode(embaralhado)se len(embaralhado) = 0 thenbase64Decode = ""exit functionend ifdim realLenrealLen = len(embaralhado)do while mid(embaralhado, realLen, 1) = "="realLen = realLen - 1loopdim ret, ndx, by4, primeiro, segundo, terceiro, quartoret = ""by4 = (realLen / 4) * 4ndx = 1do enquanto ndx <= by4first = Base64DecMap(asc(mid(embaralhado, ndx+0, 1)))segundo = Base64DecMap(asc(mid(embaralhado, ndx+1, 1)))terceiro = Base64DecMap(asc(mid(embaralhado, ndx+2, 1) ))quarto = Base64DecMap(asc(mid(embaralhado, ndx+3, 1)))ret = ret & chr( ((primeiro * 4) AND 255) + ((segundo / 16) AND 3))ret = ret & chr( ((segundo * 16) AND 255) + ((terceiro / 4) AND 15))ret = ret & chr( ((terceiro * 64) AND 255) + (quarto AND 63))ndx = ndx + 4loopif ndx < realLen thenfirst = Base64DecMap(asc(mid(embaralhado, ndx+0, 1)))segundo = Base64DecMap(asc(mid(embaralhado, ndx+1, 1)))ret = ret & chr( ((primeiro * 4) E 255) + ((segundo / 16) E 3))se realLen MOD 4 = 3 thenthird = Base64DecMap(asc(mid(scrambled,ndx+2,1)))ret = ret & chr( ((second * 16) AND 255) + ((third / 4) AND 15))end ifend ifbase64Decode = retEND FUNÇÃO%>
Como usar:
' Inicializa a chamada initCodecsResponse.Write(base64Encode("A string que desejo criptografar no Script Home"))Response.Write(base64Decode("bWFyczIwMTAwMjIw0"))