1. 程式人生 > >JavaScript 加密方法(Hash算法)

JavaScript 加密方法(Hash算法)

系列 分享圖片 加密方式 技術分享 ascii 用例 img esc n+1

簡單羅列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 MD5.js source code


    console.log(hex_md5("chenjy 1225!"));
    //basic-64編碼
    console.log(b64_md5("chenjy 1225!"));
    
    output:6e065c650d8258f73bac5a3cd8f88f47
    
    output:bgZcZQ2CWPc7rFo82PiPRw

SHA家族

SHA家族是一個密碼散列函數家族,分別是SHA-1

SHA-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-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

Blizzard one way hash


技術分享圖片


據說是我大暴雪很經典的Hash算法。

Blizzard one way hash Blizzard

JavaScript 加密方法(Hash算法)