JavaScript实现的encode64加密算法实例分析

前端之家收集整理的这篇文章主要介绍了JavaScript实现的encode64加密算法实例分析前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了JavaScript实现的encode64加密算法。分享给大家供大家参考。具体如下:

这段JavaScript代码可实现encode64加密算法,速度还是相当不错的。

> 6) & 0x3f); s += codeChar.charAt((v >> 12) & 0x3f); s += codeChar.charAt((v >> 18)); } if (res == 1) {//字节余一位时候,补2个字符,64*64>256 v = a[i - 2]; s += codeChar.charAt(v & 0x3f); s += codeChar.charAt((v >> 6) & 0x3f); } else if (res == 2) { //字节余2位的时候,补3个字节,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) { //正确的字节数肯定是余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相关文章