JavaScript實(shí)現(xiàn)的encode64加密算法實(shí)例分析
本文實(shí)例講述了JavaScript實(shí)現(xiàn)的encode64加密算法。分享給大家供大家參考。具體如下:
這段JavaScript代碼可實(shí)現(xiàn)encode64加密算法,速度還是相當(dāng)不錯(cuò)的。
//encode64編解碼
(function() {
var codeChar = "PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh";
window.encode64 = function(str) {
var s = "";
var a = strToBytes(str);
//取得字串的字節(jié)數(shù)組, 數(shù)組長度是字串長度的2倍.
var res = a.length % 3;
//3個(gè)字節(jié)一組進(jìn)行處理, 余下特殊處理
var i = 2, v;
for (; i < a.length; i += 3) {
//每3個(gè)字節(jié)用4個(gè)字符表示,
//相當(dāng)于3個(gè)字符(實(shí)際上是6個(gè)字節(jié))用8個(gè)字符編碼(實(shí)際為16個(gè)字節(jié))
//看起來容量膨脹了很多, 但是在啟用壓縮的情況下, 這些又被抵消掉了
v = a[i - 2] + (a[i - 1] << 8) + (a[i] << 16);
s += codeChar.charAt(v & 0x3f);
s += codeChar.charAt((v >> 6) & 0x3f);
s += codeChar.charAt((v >> 12) & 0x3f);
s += codeChar.charAt((v >> 18));
}
if (res == 1) {//字節(jié)余一位時(shí)候, 補(bǔ)2個(gè)字符, 64*64>256
v = a[i - 2];
s += codeChar.charAt(v & 0x3f);
s += codeChar.charAt((v >> 6) & 0x3f);
} else if (res == 2) {
//字節(jié)余2位的時(shí)候, 補(bǔ)3個(gè)字節(jié), 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) {
//正確的字節(jié)數(shù)肯定是余2或3, 沒有1的情況, 如果出現(xiàn), 舍棄.
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);
};
})();
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JS DOM實(shí)現(xiàn)鼠標(biāo)滑動(dòng)圖片效果
這篇文章主要為大家詳細(xì)介紹了JS DOM實(shí)現(xiàn)鼠標(biāo)滑動(dòng)圖片效果,只要將鼠標(biāo)放上該商品的區(qū)域,原本折疊起來的商品便會(huì)自動(dòng)展開,感興趣的小伙伴們可以參考一下2016-03-03
javascript-表格排序(降序/反序)實(shí)現(xiàn)介紹(附圖)
使用了Array方法、sort:降序、reverse:反序完成了基本功能,對(duì)于聯(lián)合排序沒有實(shí)現(xiàn),感興趣的朋友可以參考下哈2013-05-05
設(shè)置cookie指定時(shí)間失效(實(shí)例代碼)
下面小編就為大家?guī)硪黄O(shè)置cookie指定時(shí)間失效(實(shí)例代碼)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
利用Three.js如何實(shí)現(xiàn)陰影效果實(shí)例代碼
使用three.js可以方便的讓我們?cè)诰W(wǎng)頁中做出各種不同的3D效果,下面這篇文章主要給大家介紹了關(guān)于利用Three.js如何實(shí)現(xiàn)陰影效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-09-09
Textarea輸入字?jǐn)?shù)限制實(shí)例(兼容iOS&安卓)
下面小編就為大家?guī)硪黄猅extarea輸入字?jǐn)?shù)限制實(shí)例(兼容iOS&安卓)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
微信小程序canvas動(dòng)態(tài)時(shí)鐘

