base64加密jquery前端解密中文乱码问题

jquery前端解密js文件jquery.base64.js可自行下载。

引用该js文件后即可在前端引用其中的解密方法

/*
功能:获取cookies函数 
参数:name,cookie名字
*/
function getbase64Cookie(name) {
    var arr = document.cookie.match(new RegExp("(^| )" + name + "=([^;]*)(;|$)"));
    if (arr != null) {
        var a = arr[2];
        return $.base64.decode(a);
    } else {
        return null;
    }
}

解密后发现中文仍有乱码的情况,原来js前端默认采用utf-16方式编码。而后台数据加密前将数据转成了utf-8格式,因此解密后需要进行格式转换,从utf-8转为utf-16。

utf16转为utf8

var utf16to8 = function(str) {
                var out, i, len, c;
                out = "";
                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));
                    }
                }
                return out;
            }

utf8转为utf16

 var utf8to16 = function(str) {
                var out, i, len, c;
                var char2, char3;
                out = "";
                len = str.length;
                i = 0;
                while(i < len) {
                    c = str.charCodeAt(i++);
                    switch(c >> 4)
                    {
                        case 0: case 1: case 2: case 3: case 4: case 5: case 6:case7:
                        // 0xxxxxxx
                        out += str.charAt(i-1);
                        break;
                        case 12: case 13:
                        // 110x xxxx 10xx xxxx
                        char2 = str.charCodeAt(i++);
                        out += String.fromCharCode(((c & 0x1F) << 6) | (char2&0x3F));
                        break;
                        case 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));
                            break;
                    }
                }
                return out;
            }

调用完getbase64Cookie方法后,再调用utf8to16方法。

 

展开阅读全文

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