JavaScript 中对称加密和不对称加密算法(Hash 算法)

发布于 2020-02-08 19:39:31 字数 2751 浏览 1801 评论 0

简单罗列 JavaScript 中的 Hash 加密算法,这些文件可以直接引入后使用,文件里面有详细的注释,如果是简单的加密我们可以使用JavaScript原生的方法escapeunescape

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 子分组,最后经过一系列的算法生成 432bit128bit 的散列值。

console.log(hex_md5("chenjy 1225!"));
//basic-64编码
console.log(b64_md5("chenjy 1225!"));

output:6e065c650d8258f73bac5a3cd8f88f47
output:bgZcZQ2CWPc7rFo82PiPRw

SHA家族

SHA家族是一个密码散列函数家族,分别是SHA-1SHA-224SHA-256SHA-384SHA-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

同样分为为1632bit子分组,最后经过一系列的算法生成532bit160bit的散列值。

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文