欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實(shí)現(xiàn)的encode64加密算法實(shí)例分析

 更新時(shí)間:2015年04月15日 15:07:15   作者:ishare  
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的encode64加密算法,實(shí)例分析了javascript處理encode64編碼針對(duì)字符串加密的技巧,非常簡潔實(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腳本分頁代碼分享(7種樣式)

    js腳本分頁代碼分享(7種樣式)

    這篇文章主要介紹了7種JS腳本分頁樣式,推薦給大家,有需要的小伙伴可以參考下。
    2015-08-08
  • 微信小程序canvas動(dòng)態(tài)時(shí)鐘

    微信小程序canvas動(dòng)態(tài)時(shí)鐘

    這篇文章主要為大家詳細(xì)介紹了微信小程序canvas動(dòng)態(tài)時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • JS圖像無縫滾動(dòng)腳本非常好用

    JS圖像無縫滾動(dòng)腳本非常好用

    最好用的JS圖像無縫滾動(dòng)腳本,根據(jù)需要改改寬度和圖像個(gè)數(shù)就可以了,需要的朋友可以參考下
    2014-02-02
  • 最新評(píng)論