私用js加密算法

var CODE={
en:function(str){
return EIGHT.en(BASE64.en(str));
},
de:function(str){
return BASE64.de(EIGHT.de(str));
}
}


var BASE64={
 
    enKey: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',
    deKey: new Array(
        -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
    ),
 
    en: function(src){
        
        var str=new Array();
        var ch1, ch2, ch3;
        var pos=0;


        while(pos+3<=src.length){
            ch1=src.charCodeAt(pos++);
            ch2=src.charCodeAt(pos++);
            ch3=src.charCodeAt(pos++);
            str.push(this.enKey.charAt(ch1>>2), this.enKey.charAt(((ch1<<4)+(ch2>>4))&0x3f));
            str.push(this.enKey.charAt(((ch2<<2)+(ch3>>6))&0x3f), this.enKey.charAt(ch3&0x3f));
        }
        if(pos<src.length){
            ch1=src.charCodeAt(pos++);
            str.push(this.enKey.charAt(ch1>>2));
            if(pos<src.length){
                ch2=src.charCodeAt(pos);
                str.push(this.enKey.charAt(((ch1<<4)+(ch2>>4))&0x3f));
                str.push(this.enKey.charAt(ch2<<2&0x3f), '=');
            }else{
                str.push(this.enKey.charAt(ch1<<4&0x3f), '==');
            }
        }
        return str.join('');
    },
 
    de: function(src){
        var str=new Array();
        var ch1, ch2, ch3, ch4;
        var pos=0;
        src=src.replace(/[^A-Za-z0-9\+\/]/g, '');
        while(pos+4<=src.length){
            ch1=this.deKey[src.charCodeAt(pos++)];
            ch2=this.deKey[src.charCodeAt(pos++)];
            ch3=this.deKey[src.charCodeAt(pos++)];
            ch4=this.deKey[src.charCodeAt(pos++)];
            str.push(String.fromCharCode(
                (ch1<<2&0xff)+(ch2>>4), (ch2<<4&0xff)+(ch3>>2), (ch3<<6&0xff)+ch4));
        }
        if(pos+1<src.length){
            ch1=this.deKey[src.charCodeAt(pos++)];
            ch2=this.deKey[src.charCodeAt(pos++)];
            if(pos<src.length){
                ch3=this.deKey[src.charCodeAt(pos)];
                str.push(String.fromCharCode((ch1<<2&0xff)+(ch2>>4), (ch2<<4&0xff)+(ch3>>2)));
            }else{
                str.push(String.fromCharCode((ch1<<2&0xff)+(ch2>>4)));
            }
        }
        return str.join('');
    }
};


var EIGHT={

en:function(str){
var code = new Array();
var key="";
        for(var i=0;i<str.length;i++){
key=str.charCodeAt(i).toString(8);
if(key.length<3)
key+="%";
if(key.length<3)
key+="*";
code+=key;
}
        return code;
},

de:function(str){
var key = new Array();
var pos=0;step=3;
while(pos<str.length){
key.push(str.substr(pos,step));
pos+=3;
}
    var code="";
    for(var i=0;i<key.length;i++)
        code+=String.fromCharCode(parseInt(key[i],8));
    return code;
}
}
阅读更多
上一篇Cookie
想对作者说点什么? 我来说一句

js版md5非对称加密算法

2011年11月16日 6KB 下载

加密算法js 实现 md4 md5 sha-1

2009年04月26日 7KB 下载

js-RSA加密算法

2017年09月27日 19KB 下载

js实现rsa加密算法

2014年09月21日 18KB 下载

JS 加密算法

2011年12月30日 32KB 下载

js数据加密解密

2018年04月18日 13KB 下载

base64的js实现

2009年03月04日 4KB 下载

自己保存的代码例子,私用1

2010年04月28日 63KB 下载

自己保存的代码例子,私用2

2010年04月28日 8KB 下载

js RSA加密源码

2014年07月05日 10KB 下载

没有更多推荐了,返回首页

关闭
关闭