Proof-of-Work 简称 PoW,即为工作量证明
⚫通过计算一个数值,使得拼揍上交易数据后内容的值满足规定的上限,在节点成功 找到满足的 Hash 值之后,会马上对全网进行广播打包区块,网络的节点收到广播 打包区块,会立刻对其进行验证
⚫网络中只有最快解密的区块,才会添加的账本中,其他的节点进行复制,这样就保 证了整个账本的唯一性
⚫假如节点有任何的作弊行为,都会导致网络的节点验证不通过,直接丢弃其打包的 区块,这个区块就无法记录到总账本中,作弊的节点耗费的成本就白费了,因此在 巨大的挖矿成本下,也使得矿工自觉自愿的遵守比特币系统的共识协议,也就确保 了整个系统的安全
type Block struct {
PreHash string
HashCode string
TimeStamp string
Diff int
Data string
Index int
Nonce int
}
func GenerateFirstBlock(data string) Block {
//创建第一个Block
var firstblock Block
firstblock.PreHash = "0"
firstblock.TimeStamp = time.Now().String()
firstblock.Diff = 4
firstblock.Data = data
firstblock.Index = 1
firstblock.Nonce = 0
//计算哈希,HashCode
firstblock.HashCode = GenerationHashValue(firstblock)
return firstblock
}
func GenerationHashValue(block Block) string {
var hashdata = strconv.Itoa(block.Nonce) + strconv.Itoa(block.Diff) +
strconv.Itoa(block.Index) + block.TimeStamp
//计算哈