JavaScript實現的encode64加密算法實例分析
更新時間:2015年04月15日 15:07:15 作者:ishare
這篇文章主要介紹了JavaScript實現的encode64加密算法,實例分析了javascript處理encode64編碼針對字符串加密的技巧,非常簡潔實用,需要的朋友可以參考下
本文實例講述了JavaScript實現的encode64加密算法。分享給大家供大家參考。具體如下:
這段JavaScript代碼可實現encode64加密算法,速度還是相當不錯的。
//encode64編解碼 (function() { var codeChar = "PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh"; window.encode64 = function(str) { var s = ""; var a = strToBytes(str); //取得字串的字節(jié)數組, 數組長度是字串長度的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é)數肯定是余2或3, 沒有1的情況, 如果出現, 舍棄. 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); }; })();
希望本文所述對大家的javascript程序設計有所幫助。
相關文章
javascript-表格排序(降序/反序)實現介紹(附圖)
使用了Array方法、sort:降序、reverse:反序完成了基本功能,對于聯合排序沒有實現,感興趣的朋友可以參考下哈2013-05-05