博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript 加密方法(Hash算法)
阅读量:5244 次
发布时间:2019-06-14

本文共 1823 字,大约阅读时间需要 6 分钟。

简单罗列JavaScript 中的Hash加密算法

原生的加密方式

escape和unescape

如果是简单的加密我们可以使用JavaScript原生的方法escapeunescape

escape方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码:* @ - _ + . /。其他所有的字符都会被转义序列替换。

console.log("output:" + escape("chenjy 1225! "));        console.log("output:" + unescape(escape("chenjy 1225! ")));        output:chenjy%201225%21%20        output:chenjy 1225!

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

算法使用

MD5js

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的散列值。

算法使用

SHA-1.js

SHA-256.js

SHA-512.js

console.log(hex_sha1("chenjy 1225!"));        console.log(hex_sha256("chenjy 1225!"));        console.log(hex_sha512("chenjy 1225!"));        output:a8a3b8b4263f7c12bbb400b6841aca472f53df0a        output:1b4d37e8177634f191a7742c6d7e3d8aaf556aae583da0944e353001344fe3b0    output:52622c1d8351011cb8ec1c4c891387d9a221c34e9e7289692070ef6656e98c4025328682cb86bd8577f6ed2b51c61559adb76685356632543db3e9020cc162f2

Blizzard one way hash


outPut


据说是我大暴雪很经典的Hash算法。

Blizzard one way hash

转载于:https://www.cnblogs.com/chenjy1225/p/9661337.html

你可能感兴趣的文章
masm32V11配置
查看>>
ASP.NET中Request.ApplicationPath、Request.FilePath、Request.Path、.Request.MapPath
查看>>
通过Python、BeautifulSoup爬取Gitee热门开源项目
查看>>
正则表达式的用法
查看>>
线程安全问题
查看>>
集合的内置方法
查看>>
IOS Layer的使用
查看>>
Android SurfaceView实战 带你玩转flabby bird (上)
查看>>
Android中使用Handler造成内存泄露的分析和解决
查看>>
SSM集成activiti6.0错误集锦(一)
查看>>
个人作业
查看>>
下拉刷新
查看>>
linux的子进程调用exec( )系列函数
查看>>
MSChart的研究
查看>>
C# 索引器
查看>>
MySQLdb & pymsql
查看>>
zju 2744 回文字符 hdu 1544
查看>>
XmlDocument
查看>>
delphi 内嵌汇编例子
查看>>
SQL server 2012 安装SQL2012出现报错: 启用 Windows 功能 NetFx3 时出错
查看>>