>웹 프론트엔드 >JS 튜토리얼 >일반적으로 사용되는 JS 암호화 인코딩 알고리즘 코드 페이지 1/2_Hacker 특성

일반적으로 사용되는 JS 암호화 인코딩 알고리즘 코드 페이지 1/2_Hacker 특성

PHP中文网
PHP中文网원래의
2016-05-16 19:00:021256검색

1: UTF8 인코딩 기능

코드 복사 코드는 다음과 같습니다.


function URLEncode(Str){
if(Str==null||Str=="")
return "";
var newStr=""
function toCase(sStr);
return sStr.toString(16).toUpperCase();
}
for(var i=0,icode,len=Str.length;iicode=Str .charCodeAt( i);
if( icode<0x10)
newStr ="%0" icode.toString(16).toUpperCase()
else if(icode<0x80){
if (icode= =0x20)
newStr =" "; else if((icode>=0x30&&icode


2: Base64 인코딩, 디코딩 기능

코드 복사 코드는 다음과 같습니다.


var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 /";
var base64DecodeChars = 새 배열(
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 , -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, - 1, -1, -1, 63,
52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1 ,
-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
-1, 26, 27, 28, 29, 30, 31, 32, 33, 34 , 35, 36, 37, 38, 39, 40,
41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1);
function base64encode(str) {
var out, i, len;
var c1, c2, c3;
len = str.length;
나는 = 0;
아웃 = "";
while(i < len) {
c1 = str.charCodeAt(i ) & 0xff;
if(i == len)
{
out = base64EncodeChars.charAt(c1 >> 2);
out = base64EncodeChars.charAt((c1 & 0x3) << 4);
아웃 = "==";
휴식;
}
c2 = str.charCodeAt(i );
if(i == len)
{
out = base64EncodeChars.charAt(c1 >> 2);
out = base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
out = base64EncodeChars.charAt((c2 & 0xF) << 2);
아웃 = "=";
휴식;
}
c3 = str.charCodeAt(i );
out = base64EncodeChars.charAt(c1 >> 2);
out = base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
out = base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6));
out = base64EncodeChars.charAt(c3 & 0x3F);
}
반환;
}
function base64decode(str) {
var c1, c2, c3, c4;
var i, len, out;
len = str.length;
나는 = 0;
아웃 = "";
while(i < len) {
/* c1 */
do {
c1 = base64DecodeChars[str.charCodeAt(i ) & 0xff];
} while(i < len && c1 == -1);
if(c1 == -1)
break;
/* c2 */
do {
c2 = base64DecodeChars[str.charCodeAt(i ) & 0xff];
} while(i < len && c2 == -1);
if(c2 == -1)
break;
out = String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4));
/* c3 */
do {
c3 = str.charCodeAt(i ) & 0xff;
if(c3 == 61)
반환;
c3 = base64DecodeChars[c3];
} while(i < len && c3 == -1);
if(c3 == -1)
break;
out = String.fromCharCode(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2));
/* c4 */
do {
c4 = str.charCodeAt(i ) & 0xff;
if(c4 == 61)
반환;
c4 = base64DecodeChars[c4];
} while(i < len && c4 == -1);
if(c4 == -1)
break;
out = String.fromCharCode(((c3 & 0x03) << 6) | c4);
}
반환;
}
function utf16to8(str) {
var out, i, len, c;
아웃 = "";
len = str.length;
for(i = 0; i < len; i ) {
c = str.charCodeAt(i);
if ((c >= 0x0001) && (c <= 0x007F)) {
out = str.charAt(i);
} else if (c > 0x07FF) {
out = String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
out = String.fromCharCode(0x80 | ((c >> 6) & 0x3F));
out = String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
} else {
out = String.fromCharCode(0xC0 | ((c >> 6) & 0x1F));
out = String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
}
}
반환;
}
function utf8to16(str) {
var out, i, len, c;
var char2, char3;
아웃 = "";
len = str.length;
나는 = 0;
while(i < len) {
c = str.charCodeAt(i );
스위치(c >> 4)
{
케이스 0: 케이스 1: 케이스 2: 케이스 3: 케이스 4: 케이스 5: 케이스 6: 케이스 7:
// 0xxxxxxx
out = str.charAt(i-1);
휴식;
사례 12: 사례 13:
// 110x xxxx 10xx xxxx
char2 = str.charCodeAt(i );
out = String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
휴식;
사례 14:
// 1110 xxxx 10xx xxxx 10xx xxxx
char2 = str.charCodeAt(i );
char3 = str.charCodeAt(i );
out = String.fromCharCode(((c & 0x0F) << 12) |
((char2 & 0x3F) << 6) |
((char3 & 0x3F) << ;0));
휴식;
}
}
반환;
}
function doit() {
var f = document.f
f.output.value = base64encode(utf16to8(f.source.value))
f.decode.value = utf8to16(base64decode(f.output.value))
}



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.