go语言-计算哈希值

//通过计算获取哈希值
func (b *Block)SetHash(){
   timestamp := []byte(strconv.FormatInt(b.Timestamp,10))
   headers := bytes.Join([][]byte{b.PrevBlockHash, b.Data, timestamp},[]byte{})
   hash := sha256.Sum256(headers)
   b.Hash = hash[:]
}

sha256作用

哈希值用作表示大量数据的固定大小的唯一值。数据的少量更改会在哈希值中产生不可预知的大量更改。

SHA256 算法的哈希值大小为 256 位。

这是一个抽象类。此类的唯一实现是 SHA256Managed。

SHA家族

安全散列算法(英语:Secure Hash Algorithm,缩写为SHA)是一个密码散列函数家族,是FIPS所认证的安全散列算法。能计算出一个数字消息所对应到的,长度固定的字符串(又称消息摘要)的算法。且若输入的消息不同,它们对应到不同字符串的机率很高。

SHA家族的五个算法,分别是SHA-1、SHA-224、SHA-256、SHA-384,和SHA-512,由美国国家安全局(NSA)所设计,并由美国国家标准与技术研究院(NIST)发布;是美国的政府标准。后四者有时并称为SHA-2。SHA-1在许多安全协定中广为使用,包括TLS和SSL、PGP、SSH、S/MIME和IPsec,曾被视为是MD5(更早之前被广为使用的杂凑函数)的后继者。但SHA-1的安全性如今被密码学家严重质疑;虽然至今尚未出现对SHA-2有效的攻击,它的算法跟SHA-1基本上仍然相似;因此有些人开始发展其他替代的杂凑算法。 [1] 

 

你可能感兴趣的:(golang)