主頁(yè) > 知識(shí)庫(kù) > go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能

go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能

熱門(mén)標(biāo)簽:不封卡外呼系統(tǒng) 仙桃400電話辦理 重慶慶云企業(yè)400電話到哪申請(qǐng) 湛江crm外呼系統(tǒng)排名 宿遷便宜外呼系統(tǒng)代理商 上海極信防封電銷(xiāo)卡價(jià)格 地圖標(biāo)注免費(fèi)定制店 鄭州智能語(yǔ)音電銷(xiāo)機(jī)器人價(jià)格 寧波語(yǔ)音外呼系統(tǒng)公司

介紹

簽名的輸入:

  • 待簽名的交易數(shù)據(jù),包括輸入和輸出
  • 引用的UTXO信息
  • 私鑰

簽名的輸出:

  • 數(shù)字?jǐn)?shù)字簽名
  • 公鑰

簽名的目的

  • 證明交易所引用的UTXO的確屬于付款人
  • 證明交易的所有數(shù)據(jù)的確是付款人提供的,且未被修改過(guò)

簽名中需要的數(shù)據(jù)

  • UTXO中的PubKeyHash,這描述了付款人
  • 新生成UTXO中的PubKeyHash,這描述了收款人
  • 由于每一筆交易都可能引用多個(gè)UTXO,因?yàn)槎鄠€(gè)UTXO可能存在于多條交易中。所以我們需要遍歷所以的引用交易,并對(duì)他們逐個(gè)簽名

簽名過(guò)程

用解鎖腳本解鎖對(duì)應(yīng)的UTXO鎖定腳本

 簽名

//簽名的具體實(shí)現(xiàn), 參數(shù):私鑰,inputs里面所有引用的交易的結(jié)構(gòu)map[string]Transaction
func (tx *Transaction) Sign(privateKey *ecdsa.PrivateKey, prevTXs map[string]Transaction){
	//1. 創(chuàng)建一個(gè)當(dāng)前交易的副本:txCopy,使用函數(shù):TrimmedCopy:要把Signature和PubKey字段設(shè)置為null
	//2. 循環(huán)遍歷txCopy的inputs,得到這個(gè)input索引的output的公鑰哈希
	//3. 生成簽名的數(shù)據(jù),要簽名的數(shù)據(jù)一定是哈希值
		//a. 我們對(duì)每一個(gè)input都簽名一次,簽名的數(shù)據(jù)是由當(dāng)前input引用的output的哈希+當(dāng)前的outputs(都存在當(dāng)前這個(gè)txCopy里面)
		//b. 對(duì)拼好的txCopy進(jìn)行哈希處理,SetHash得到TXID,這個(gè)TXID就是我們要簽名的最終數(shù)據(jù)
	//4. 執(zhí)行簽名動(dòng)作,得到r,s字節(jié)流
	//5. 放到我們簽名的inputs的Signature中

	if tx.IsCoinbase(){
		return
	}

	//1.
	txCopy := tx.TrimmedCopy()

	//2.
	for i, input := range txCopy.TXInputs{
		prevTX := prevTXs[string(input.Txid)]

		if len(prevTX.TXID) == 0{
			log.Panic("引用的交易無(wú)效\n")
		}

		//不要對(duì)input進(jìn)行賦值,這是一個(gè)副本,要對(duì)txCopy.TXInput[xx]進(jìn)行操作,否則無(wú)法把pubKeyHash傳進(jìn)來(lái)
		txCopy.TXInputs[i].PubKey = prevTX.TXOutputs[input.Index].PubKeyHash

		//3.
		//ab.
		//所需要的三個(gè)數(shù)據(jù)都具備了,開(kāi)始做哈希處理
		txCopy.SetHash()

		//還原,以免影響后面的input簽名
		txCopy.TXInputs[i].PubKey = nil
		signDataHash := txCopy.TXID

		//4.
		r, s, err := ecdsa.Sign(rand.Reader, privateKey, signDataHash)
		if err != nil{
			log.Panic(err)
		}

		//5.
		signature := append(r.Bytes(), s.Bytes()...)
		tx.TXInputs[i].Signature = signature
	}

}

校驗(yàn)

func (tx *Transaction) Verify (prevTXs map[string]Transaction) bool{
	if tx.IsCoinbase(){
		return true
	}

	//1. 得到簽名的數(shù)據(jù)
	//2. 得到signature,反退回r,s
	//3. 拆解PubKey, X,Y得到原生公鑰
	//4. Verify

	//1.
	txCopy := tx.TrimmedCopy()

	for i, input := range tx.TXInputs{
		prevTX := prevTXs[string(input.Txid)]
		if len(prevTX.TXID) == 0{
			log.Panic("引用的交易無(wú)效\n")
		}

		txCopy.TXInputs[i].PubKey = prevTX.TXOutputs[input.Index].PubKeyHash
		txCopy.SetHash()
		dataHash := txCopy.TXID
		//2
		signature := input.Signature //拆r,s
		//3
		pubKey := input.PubKey //拆r,s

		r := big.Int{}
		s := big.Int{}

		r.SetBytes(signature[:len(signature)/2])
		s.SetBytes(signature[len(signature)/2:])

		X := big.Int{}
		Y := big.Int{}

		//b. pubKey平均分,前半部分給X,后半部分給Y
		X.SetBytes(pubKey[:len(pubKey)/2])
		Y.SetBytes(pubKey[len(pubKey)/2:])

		pubKeyOrigin := ecdsa.PublicKey{elliptic.P256(), X, Y}

		//4
		if !ecdsa.Verify(pubKeyOrigin, dataHash, r, s){
			return false
		}

	}
	return true
}

拷貝交易

//拷貝方法,用來(lái)引用交易
func (tx *Transaction) TrimmedCopy() Transaction{
	var inputs []TXInput
	var outputs []TXOutput

	for _, input := range tx.TXInputs{
		inputs = append(inputs, TXInput{input.Txid, input.Index, nil, nil})
	}

	for _, output := range tx.TXOutputs{
		outputs = append(outputs, output)
	}

	return Transaction{tx.TXID, inputs, outputs}
}

最后

本套源碼來(lái)源于黑馬程序員,在此十分感謝黑馬程序員的教程!

源碼:https://gitee.com/xiaoshengdada/go_bitcoin/tree/master/v6
如果有任何問(wèn)題可以來(lái)微信群交流,另外群里有學(xué)習(xí)資料,可以自行下載。一起學(xué)習(xí)進(jìn)步。

到此這篇關(guān)于go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能的文章就介紹到這了,更多相關(guān)go語(yǔ)言比特幣交易簽名校驗(yàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 教你用go語(yǔ)言實(shí)現(xiàn)比特幣交易功能(Transaction)
  • go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)錢(qián)包的原理解析
  • go語(yǔ)言實(shí)戰(zhàn)之實(shí)現(xiàn)比特幣地址校驗(yàn)步驟

標(biāo)簽:青海 安康 遼寧 電子產(chǎn)品 西雙版納 海南 物業(yè)服務(wù) 儋州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能》,本文關(guān)鍵詞  語(yǔ)言,實(shí)現(xiàn),簡(jiǎn)易,比特,幣,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于go語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易比特幣系統(tǒng)之交易簽名及校驗(yàn)功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章