亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2021年04月08日 10:47:42   作者:小圣.  
這篇文章主要介紹了go語言實現(xiàn)簡易比特幣系統(tǒng)之交易簽名及校驗功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

介紹

簽名的輸入:

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

簽名的輸出:

  • 數(shù)字數(shù)字簽名
  • 公鑰

簽名的目的

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

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

  • UTXO中的PubKeyHash,這描述了付款人
  • 新生成UTXO中的PubKeyHash,這描述了收款人
  • 由于每一筆交易都可能引用多個UTXO,因為多個UTXO可能存在于多條交易中。所以我們需要遍歷所以的引用交易,并對他們逐個簽名

簽名過程

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

 簽名

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

		//不要對input進行賦值,這是一個副本,要對txCopy.TXInput[xx]進行操作,否則無法把pubKeyHash傳進來
		txCopy.TXInputs[i].PubKey = prevTX.TXOutputs[input.Index].PubKeyHash

		//3.
		//ab.
		//所需要的三個數(shù)據(jù)都具備了,開始做哈希處理
		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
	}

}

校驗

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("引用的交易無效\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
}

拷貝交易

//拷貝方法,用來引用交易
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}
}

最后

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

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

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

相關(guān)文章

  • Golang實現(xiàn)解析JSON的三種方法總結(jié)

    Golang實現(xiàn)解析JSON的三種方法總結(jié)

    這篇文章主要為大家詳細介紹了Golang實現(xiàn)解析JSON的三種方法,文中的示例代碼講解詳細,對我們學(xué)習(xí)了解JSON有一定幫助,需要的可以參考一下
    2022-09-09
  • jenkins構(gòu)建go及java項目的方法

    jenkins構(gòu)建go及java項目的方法

    這篇文章主要介紹了jenkins構(gòu)建go及java項目,本文通過圖文實例相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值了,需要的朋友可以參考下
    2021-04-04
  • 深入理解Go高級并發(fā)模式編寫更高效可擴展的應(yīng)用程序

    深入理解Go高級并發(fā)模式編寫更高效可擴展的應(yīng)用程序

    Go對并發(fā)提供了強大的原生支持,本文討論Go的高級并發(fā)模式,理解這些并發(fā)模式,可以幫助我們編寫高效的Go應(yīng)用程序,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-02-02
  • 深入了解Golang網(wǎng)絡(luò)編程Net包的使用

    深入了解Golang網(wǎng)絡(luò)編程Net包的使用

    net包主要是增加?context?控制,封裝了一些不同的連接類型以及DNS?查找等等,同時在有需要的地方引入?goroutine?提高處理效率。本文主要和大家分享下在Go中網(wǎng)絡(luò)編程的實現(xiàn),需要的可以參考一下
    2022-07-07
  • Go語言中的字符串處理方法示例詳解

    Go語言中的字符串處理方法示例詳解

    Go語言的字符串是使用UTF-8編碼的。UTF-8是Unicode的實現(xiàn)方式之一。這篇文章主要介紹了Go語言中的字符串處理方法,需要的朋友可以參考下
    2018-10-10
  • Golang異常處理之優(yōu)雅地控制和處理異常

    Golang異常處理之優(yōu)雅地控制和處理異常

    在Golang中,異常處理是非常重要的一部分,能夠有效地控制和處理代碼中的異常情況。通過Golang的異常處理機制,可以優(yōu)雅地捕獲和處理異常,保障代碼的可靠性和穩(wěn)定性。同時,Golang還提供了豐富的工具和API,幫助開發(fā)者更加輕松地進行異常處理
    2023-04-04
  • golang常用加密解密算法總結(jié)(AES、DES、RSA、Sha1、MD5)

    golang常用加密解密算法總結(jié)(AES、DES、RSA、Sha1、MD5)

    在項目開發(fā)過程中,當(dāng)操作一些用戶的隱私信息,本文主要主要介紹了golang常用加密解密算法總結(jié)(AES、DES、RSA、Sha1MD5),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Go語言實現(xiàn)棧與隊列基本操作學(xué)家

    Go語言實現(xiàn)棧與隊列基本操作學(xué)家

    go語言中,并沒有棧與隊列相關(guān)的數(shù)據(jù)結(jié)構(gòu),但是我們可以借助切片來實現(xiàn)棧與隊列的操作;接下來我們一起實現(xiàn)棧與隊列基本操作,感興趣的可以了解一下
    2022-11-11
  • Golang 中的可測試示例函數(shù)(Example Function)詳解

    Golang 中的可測試示例函數(shù)(Example Function)詳解

    這篇文章詳細講解了 Golang 中的可測試示例函數(shù),示例函數(shù)類似于單元測試函數(shù),但沒有  *testing 類型的參數(shù),編寫示例函數(shù)也是很容易的,本文就通過代碼示例給大家介紹一下Golang的可測試示例函數(shù),需要的朋友可以參考下
    2023-07-07
  • 詳解如何在Go中實現(xiàn)優(yōu)雅停止

    詳解如何在Go中實現(xiàn)優(yōu)雅停止

    和其他語言相比,Go 中有相同也有不同,相同的是實現(xiàn)思路上和其他語言沒啥差異,不同在于 Go 采用的是 goroutine + channel 的并發(fā)模型,與傳統(tǒng)的進程線程相比,實現(xiàn)細節(jié)上存在差異,本文將從實際場景和它的一般實現(xiàn)方式展開,逐步討論這個話題,需要的朋友可以參考下
    2024-04-04

最新評論