本文实例讲述了JavaScript实现的encode64加密算法。分享给大家供大家参考。具体如下:
这段JavaScript代码可实现encode64加密算法,速度还是相当不错的。
> 6) & 0x3f);
s += codeChar.charAt((v >> 12) & 0x3f);
s += codeChar.charAt((v >> 18));
}
if (res == 1) {//字节余一位时候,补2个字符,64*64>256
v = a[i - 2];
s += codeChar.charAt(v & 0x3f);
s += codeChar.charAt((v >> 6) & 0x3f);
} else if (res == 2) {
//字节余2位的时候,补3个字节,64*64*64>256*256,所以是可行的
v = a[i - 2] + (a[i - 1] << 8);
s += codeChar.charAt(v & 0x3f);
s += codeChar.charAt((v >> 6) & 0x3f);
s += codeChar.charAt((v >> 12) & 0x3f);
}
return s;
};
window.decode64 = function(codeStr) {
var dic = [];
for (var i = 0; i < codeChar.length; i++) {
dic[codeChar.charAt(i)] = i;
}
var code = [];
var res = codeStr.length % 4;
var i = 3,v;
for (; i < codeStr.length; i += 4) {
v = dic[codeStr.charAt(i - 3)];
v += dic[codeStr.charAt(i - 2)] << 6;
v += dic[codeStr.charAt(i - 1)] << 12;
v += dic[codeStr.charAt(i)] << 18;
code.push(v & 0xff,(v >> 8) & 0xff,(v >> 16) & 0xff);
}
if (res == 2) {
//正确的字节数肯定是余2或3,没有1的情况,如果出现,舍弃.
v = dic[codeStr.charAt(i - 3)];
v += dic[codeStr.charAt(i - 2)] << 6;
code.push(v & 0xff);
} else if (res == 3) {
v = dic[codeStr.charAt(i - 3)];
v += dic[codeStr.charAt(i - 2)] << 6;
v += dic[codeStr.charAt(i - 1)] << 12;
code.push(v & 0xff,(v >> 8) & 0xff);
}
return strFromBytes(code);
};
})();
希望本文所述对大家的javascript程序设计有所帮助。