下面的js代码首先将给定的数据字符串,跟指定的密匙字符串做异或运算,接着将结果序列进行base64编码,
下面同时给出了解密算法跟,base64还原函数
代码如下:
function secode(opArray) {
var _local2 = opArray;
var strEnd="=";
var _local3 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
var bits;
var decOut = new Array ();
var _local1 = 0;
var j = 0;
_local1 = 0;
while (_local1 < _local2.length) {
//第一个元素(这里前提是单字节)向前移动2个字节,
//第二个移动1字节,第三个不移动
//那么 | 后的结果是,形成一个 3字节的数据如下
//xxxxxxxx0000000000000000
//00000000xxxxxxxx00000000
//0000000000000000xxxxxxxx
//注意bits是一个正整数,其值等与上面3组数 |(异) 后的数值
//16515072的二进制表示为:1111 1100, 0000 0000 ,0000 0000
//那么 bits & 16515072 后,就是取bits的前6位
//>>18 表示右移动 18为注意 bits & 16515072 后是正数,那么>>18时高位补的是00,
// 正数高位第一位为0,负数为1
//这样((bits & 16515072)>>18)的值就是其在_local3中对应字的符位置.
bits = ((_local2[_local1]<<16) | (_local2[_local1+1]<<8) | (_local2[_local1+2]));
decOut[j++] = _local3.charAt((bits & 16515072) >> 18);
decOut[j++] = _local3.charAt((bits & 258048) >> 12);
decOut[j++] = _local3.charAt((bits & 4032) >> 6);
decOut[j++] = _local3.charAt(bits & 63);
_local1 = _local1 + 3;
}
//另外258048其二进制表示为 11 ,1111 0000 ,0000 0000
// 等价于0000 0011 ,1111 0000 ,0000 0000 (正数高位为0)
//当字节数不是3的整数倍时,_local2[_local1+1],或_local2[_local1+2] 其值(下标已经超标)是0,
//也正好符合base64不足补零的定义
switch(_local2.length%3){
//多一个字节时映射成的4字接有2个字节里无数据(纯零)应此丢弃
//多2个字节时,丢弃一个,而正好是,末尾不加"=",故将strEnd="" 设置为空.
case 1:decOut.pop();decOut.pop();break;
case 2:decOut.pop();break;
case 0:strEnd="";break;
}
decOut.push(strEnd);
return (decOut.join(""));
}
function encode(var1, key) {
var _local3 = var1;
var2 = new Array();
var _local2 = 0;
var _local1 = 0;
while (_local1 < _local3.length) {
var2.push(_local3.charCodeAt(_local1) ^ key.charCodeAt(_local2++));
//当key序列不够长时循环使用
if (_local2 >= key.length) {
_local2 = 0;
}
_local1++;
}
var2=secode(var2);
return (var2);
}
function decode(var1, key) {
var _local3 = var1;
_local3 = becode(_local3);
var2 = "";
var _local2 = 0;
var _local1 = 0;
while (_local1 < _local3.length) {
var2 = var2.concat(String.fromCharCode(_local3[_local1] ^ key.charCodeAt(_local2++)));
if (_local2 >= key.length) {
_local2 = 0;
}
_local1++;
}
return (var2);
}
function becode(opString) {
var _local2 = opString;
var _local3 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
var bits;
var decOut = new Array ();
var _local1 = 0;
var j = 0;
_local1 = 0;
while (_local1 < _local2.length) {
bits = ((((_local3.indexOf(_local2.charAt(_local1)) & 255) << 18) | ((_local3.indexOf(_local2.charAt(_local1 + 1)) & 255) << 12)) | ((_local3.indexOf(_local2.charAt(_local1 + 2)) & 255) << 6)) | (_local3.indexOf(_local2.charAt(_local1 + 3)) & 255);
decOut[j++] = (bits & 16711680) >> 16;
decOut[j++] = (bits & 65280) >> 8;
decOut[j++] = bits & 255;
_local1 = _local1 + 4;
}
if (_local2.charCodeAt(_local1 - 2) == 61) {
decOut.pop();
decOut.pop();
} else if (_local2.charCodeAt(_local1 - 1) == 61) {
decOut.pop();
//
}
return (decOut);
}
function base64(str){
var d=new Array();
for(var i=0;i<str.length;i++){
d.push(str.charCodeAt(i));
}alert(d);
return secode(d);
}
//说明,首先获取字符串的字节序列(Array) 使用 str.charCodeAt(i), 这里需要注意的是, charCodeAt(i)获取的值应该<=255 (单字节) 如果str中含有中文等双字节码,那么请先使用str=escape(str)对其进行编码(还原时使用unescape).
encode函数, encode里将待处理字符序列(假设已经为单字节序列),与给顶的key序列,将每个字符的Unicode值做^操作,获得一个待base64编码数组.
secode函数, 根据base64编码,将每3个字节映射成4个字节,当字节数不是3的倍数时尾部补0(bit),形成的base64字符串最后加"="
后面的两个是相应的还原函数