安全散列算法SHA(Secure Hash Algorithm)是美國國家安全局 (NSA) 設計,美國國家標準與技術研究院(NIST) 發布的一系列密碼散列函數,包括 SHA-1、SHA-224、SHA-256、SHA-384 和 SHA-512 等變體。主要適用于數字簽名標準(DigitalSignature Standard DSS)里面定義的數字簽名算法(Digital Signature Algorithm DSA)。SHA-1已經不是那邊安全了,google和微軟都已經棄用這個加密算法。為此,我們使用熱門的比特幣使用過的算法SHA-256作為實例。其它SHA算法,也可以按照這種模式進行使用。
### sha1
```go
package main
import (
"crypto/sha1"
"encoding/hex"
"fmt"
"io"
)
func main() {
str := "www.5lmh.com"
//方法一
data := []byte(str)
has := sha1.Sum(data)
shastr1 := fmt.Sprintf("%x", has) //將[]byte轉成16進制
fmt.Println(shastr1)
//方法二
w := sha1.New()
io.WriteString(w, str) //將str寫入到w中
bw := w.Sum(nil) //w.Sum(nil)將w的hash轉成[]byte格式
// shastr2 := fmt.Sprintf("%x", bw) //將 bw 轉成字符串
shastr2 := hex.EncodeToString(bw) //將 bw 轉成字符串
fmt.Println(shastr2)
}
```
輸出結果:
```
85f1dafe3287dce1d8ac1a72fe7f28faa2b0fbf7
85f1dafe3287dce1d8ac1a72fe7f28faa2b0fbf7
```
哈希值用作表示大量數據的固定大小的唯一值。數據的少量更改會在哈希值中產生不可預知的大量更改。
SHA256 算法的哈希值大小為 256 位。
### sha256
```go
package main
import (
"crypto/sha256"
"encoding/hex"
"fmt"
"io"
)
func main() {
str := "www.5lmh.com"
w := sha256.New()
io.WriteString(w, str) //將str寫入到w中
bw := w.Sum(nil) //w.Sum(nil)將w的hash轉成[]byte格式
// shastr2 := fmt.Sprintf("%x", bw) //將 bw 轉成字符串
shastr2 := hex.EncodeToString(bw) //將 bw 轉成字符串
fmt.Println(shastr2)
}
```
輸出結果:
```
e9c2efc35f3115c82bd97ae895b96db6a483a198a8b4b1c9bd8249129db7dbe9
```
### sha512
```go
package main
import (
"crypto/sha512"
"encoding/hex"
"fmt"
"io"
)
func main() {
str := "www.5lmh.com"
w := sha512.New()
io.WriteString(w, str) //將str寫入到w中
bw := w.Sum(nil) //w.Sum(nil)將w的hash轉成[]byte格式
// shastr2 := fmt.Sprintf("%x", bw) //將 bw 轉成字符串
shastr2 := hex.EncodeToString(bw) //將 bw 轉成字符串
fmt.Println(shastr2)
}
```
輸出結果:
```
f4b68e0c8a85ddac35085eb95feb398361fe5c0421922c52dc7797c699664ee13aa4297dc7f20a9cd6615bf000dde6e91cc164988f7c55fc3b4c4c516b8d78c3
```