簡單羅列JavaScript
中的Hash
加密算法html
若是是簡單的加密咱們可使用JavaScript原生的方法escape
和unescape
。算法
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算法的有以上特性因此經常使用在不少的重要應用例如數字簽名,消息認證碼。
加密
MD5是提供了一種128bit``Hash值
的密碼散列函數,.net
填充輸入信息,使其字節長度對512求餘數爲448。信息的長度擴展爲N*512+448 bit N爲整數
。
添加4個32位的連接變量3d
使其長度爲(N+1)*512 bit
,而後將每一個512bit
的組分爲16
個32bit
子分組,最後通過一系列的算法生成4
個32bit
共128bit
的散列值。code
MD5js MD5.js source codehtm
console.log(hex_md5("chenjy 1225!")); //basic-64編碼 console.log(b64_md5("chenjy 1225!")); output:6e065c650d8258f73bac5a3cd8f88f47 output:bgZcZQ2CWPc7rFo82PiPRw
SHA家族是一個密碼散列函數家族,分別是SHA-1
、SHA-224
、SHA-256
、SHA-384
和SHA-512
。
根據產生信息摘要的長度命名。blog
原理和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
one way hash
聽說是我大暴雪很經典的Hash算法。
Blizzard one way hash Blizzard