私用js加密算法

原创 2016年08月30日 18:18:55
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;
}
}

JS前端加密算法

解密操作对服务器性能颇有消耗。寻思着能不能在前端完成。于是找到了crypto-js。 crypto-js支持各类主流算法。弄个简单点的DES加密。 function decryptByDES(c...
  • super2007
  • super2007
  • 2016年04月30日 21:14
  • 4721

公网IP 私用IP

私用IP地址,通常又被称为RFC1918地址,是按照IETF RFC 1918,被公司或组织在其自有的网络中为非公开目的而使用的地址。由于不能通过路由器传输,私用IP地址不能被直接与互联网相连接;但另...
  • linqing_1216
  • linqing_1216
  • 2012年10月02日 21:10
  • 355

淘宝RSA分析与学习

淘宝,购物者的天堂。每天更有数以万计的用户登陆购买商品,其背后的技术支持,能让我们愉快的购物。 而前段时间吵得很火的,数据包劫持能够分析到你的各种行为,其中不乏网站账号密码。而为什么他们没有劫持到淘宝...
  • u014577133
  • u014577133
  • 2016年07月10日 12:14
  • 1438

加密算法之RC4

原文:http://blog.csdn.net/ly10265139/article/details/50562368  /** * TODO: * @author liyong * @date...
  • lan861698789
  • lan861698789
  • 2016年05月08日 23:09
  • 2730

js简单加密解密演示(可以自定义密码因子)

字符串加密   function encrypt(str, pwd) {   if(pwd == null || pwd.length     alert("Please ent...
  • CPTcpt123
  • CPTcpt123
  • 2014年05月13日 01:40
  • 1495

js算法--简单加密和解密

通过获取输入的字符串,用简单的charCodeAt()将字符串变成ASCII码。加密部分。 获取列表中的ASCII码,将它们变成数组。用map()遍历数组将它们输出成字符串。解密部分。...
  • xingguanghui_1134
  • xingguanghui_1134
  • 2016年09月02日 19:46
  • 4667

MD5加密算法(java及js)

为了防止用户登陆过程中信息被拦截导致信息泄露,我们应该在客户端就对用户密码进行加密。浏览器提交给服务器的是加密后的信息,即使被恶意拦截,被拦截信息也已做了加密处理,现在比较安全的一种加密算法是MD5加...
  • u012116457
  • u012116457
  • 2015年04月06日 22:22
  • 1893

利用反射动态调用组件或类成员

 使用反射动态调用类成员,需要Type类的一个方法:InvokeMember。对该方法的声明如下(摘抄于MSDN):public object InvokeMember(   string name,...
  • jsjwql
  • jsjwql
  • 2006年04月19日 10:05
  • 812

私用IP地址(Private IP Addresses)

私用IP地址,通常又被称为RFC1918地址,是按照IETF RFC 1918,被公司或组织在其自有的网络中为非公开目的而使用的地址。由于不能通过路由器传输,私用IP地址不能被直接与互联网相连接;但...
  • linuxjackaroo
  • linuxjackaroo
  • 2008年03月14日 09:07
  • 1341

Node.js加密算法

散列算法(哈希算法) //node中,使用crypto模块来实现数据的加密与解密处理 var crypto = require('crypto'); //createHash方法中,参数为指定需要使...
  • kongjunchao159
  • kongjunchao159
  • 2015年11月17日 14:31
  • 379
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:私用js加密算法
举报原因:
原因补充:

(最多只允许输入30个字)