JavaScript實現(xiàn)的encode64加密算法實例分析
來源:易賢網(wǎng) 閱讀:1306 次 日期:2015-04-20 14:08:10
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript實現(xiàn)的encode64加密算法實例分析”,方便廣大網(wǎng)友查閱!

這段JavaScript代碼可實現(xiàn)encode64加密算法,速度還是相當不錯的。

//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個字節(jié)一組進行處理, 余下特殊處理

var i = 2, v;

for (; i < a.length; i += 3) {

//每3個字節(jié)用4個字符表示,

//相當于3個字符(實際上是6個字節(jié))用8個字符編碼(實際為16個字節(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é)余一位時候, 補2個字符, 64*64>256

v = a[i - 2];

s += codeChar.charAt(v & 0x3f);

s += codeChar.charAt((v >> 6) & 0x3f);

} else if (res == 2) {

//字節(jié)余2位的時候, 補3個字節(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);

};

})();

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機網(wǎng)站地址:JavaScript實現(xiàn)的encode64加密算法實例分析

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權所有:易賢網(wǎng)