JavaScript 中对称加密和不对称加密算法(Hash 算法)
简单罗列 JavaScript
中的 Hash
加密算法,这些文件可以直接引入后使用,文件里面有详细的注释,如果是简单的加密我们可以使用JavaScript原生的方法escape
和unescape
。
Hash 算法
Hash 算法特点
- 很容易可以算出给的数值的散列数值
- 难以通过已知的散列数值推算原始信息
- 在不更改散列数值的基础上,无法更改消息内容
- 对于两条不同消息无法给出相同的散列数值
由于 Hash 算法的有以上特性所以常用在很多的重要应用例如数字签名,消息认证码。
MD5 算法
MD5 是提供了一种128bit``Hash值
的密码散列函数,
算法原理
填充输入信息,使其字节长度对 512 求余数为448。信息的长度扩展为 N*512+448 bit N为整数
,添加4个32位的链接变量
- A=0x01234567
- B=0x89abcdef
- C=0xfedcba98
- D=0x76543210
使其长度为 (N+1)*512 bit
,然后将每个 512bit
的组分为 16
个 32bit
子分组,最后经过一系列的算法生成 4
个 32bit
共 128bit
的散列值。
console.log(hex_md5("chenjy 1225!")); //basic-64编码 console.log(b64_md5("chenjy 1225!")); output:6e065c650d8258f73bac5a3cd8f88f47 output:bgZcZQ2CWPc7rFo82PiPRw
SHA家族
SHA家族是一个密码散列函数家族,分别是SHA-1
、SHA-224
、SHA-256
、SHA-384
和SHA-512
。
根据产生信息摘要的长度命名。
- SHA-1:160bit
- SHA-224:224bit
- SHA-256:256bit
- SHA-384:384bit
- SHA-512:512bit
算法原理
原理和MD5
类似,以SHA-1为例:
SHA-1
能根据2-64bit
的信息输入计算出160bit
的散列值的单向散列函数。
填充数据的时候也是512bit
为一组。在原始数据后先添加一个1
然后添加0
一直填满448bit
。
然后再添加原始数据长度64bit
,共为512bit
。
同样分为为16
个32bit
子分组,最后经过一系列的算法生成5
个32bit
共160bit
的散列值。
- SHA-1.js SHA-1.js source code
- SHA-256.js SHA-256.js source code
- SHA-512.js SHA-512.js source code
console.log(hex_sha1("chenjy 1225!")); console.log(hex_sha256("chenjy 1225!")); console.log(hex_sha512("chenjy 1225!")); output:a8a3b8b4263f7c12bbb400b6841aca472f53df0a output:1b4d37e8177634f191a7742c6d7e3d8aaf556aae583da0944e353001344fe3b0 output:52622c1d8351011cb8ec1c4c891387d9a221c34e9e7289692070ef6656e98c4025328682cb86bd8577f6ed2b51c61559adb76685356632543db3e9020cc162f2
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论