1. sha

安全散列算法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算法,也可以按照这种模式进行使用。

1.1.1. sha1

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 位。

1.1.2. sha256

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

1.1.3. sha512

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)
}

输出结果:

    f4b68e0c8a85ddac35085eb95feb398361fe5c0421922c52dc7797c699664ee13aa4297dc7f20a9cd6615bf000dde6e91cc164988

END 链接