GO創(chuàng)建區(qū)塊鏈,怎么用GO實(shí)現(xiàn)一個(gè)簡(jiǎn)單的區(qū)塊鏈?
自互聯(lián)網(wǎng)以來(lái),鎖鏈技術(shù)已被某些人稱(chēng)為最有影響力的發(fā)明。盡管公眾將區(qū)塊鏈與投機(jī)性加密貨幣同義解釋?zhuān)珔^(qū)塊鏈實(shí)際上在現(xiàn)代世界中具有不可思議的廣泛應(yīng)用。實(shí)際上,加密貨幣只是區(qū)塊鏈領(lǐng)域的一小部分,生產(chǎn)中的許多解決方案都是由私人組織領(lǐng)導(dǎo)來(lái)實(shí)現(xiàn)的。
隨著區(qū)塊鏈技術(shù)的迅速發(fā)展,技術(shù)領(lǐng)域的專(zhuān)業(yè)人員越來(lái)越需要了解區(qū)塊鏈的基礎(chǔ)知識(shí)及其技術(shù)影響力。
畢竟,實(shí)現(xiàn)自己的區(qū)塊鏈實(shí)際上并不像聽(tīng)起來(lái)那樣復(fù)雜。本文中,我們將使用2021年最流行的編程語(yǔ)言之一GoLang實(shí)現(xiàn)基本的區(qū)塊鏈。那么,讓我們開(kāi)始吧!
了解區(qū)塊鏈
區(qū)塊鏈?zhǔn)敲Q(chēng)符合其含義的少數(shù)技術(shù)之一。我們可以將區(qū)塊鏈視為通過(guò)哈希相互連接的信息塊,哈希是從輸入數(shù)據(jù)生成的加密的固定輸出。由于每個(gè)塊都通過(guò)哈希相互引用,因此如果不大幅度更改鏈的其余部分,就不可能更改鏈的任何部分。
區(qū)塊鏈中的每個(gè)塊都可以包含幾乎任何內(nèi)容的數(shù)據(jù)。一個(gè)基本框架將包括每個(gè)塊的過(guò)去交易的所有記錄。比特幣以類(lèi)似的方式工作,這就是為什么您可以一直跟蹤比特幣交易直至Satoshi首次進(jìn)行加密貨幣交易的原因。
下面我們有三個(gè)區(qū)塊來(lái)創(chuàng)建區(qū)塊鏈。第一塊是創(chuàng)世塊。由于之前沒(méi)有任何內(nèi)容,因此前一個(gè)哈希字段為空。我們?nèi)匀皇褂脮r(shí)間戳記屬性和初始事務(wù)作為哈希算法的輸入。該算法將吐出一大串?dāng)?shù)字和字母,這些數(shù)字和字母代表了創(chuàng)世紀(jì)塊的哈希值。
轉(zhuǎn)到塊2,我們將創(chuàng)世塊的哈希值用作塊2先前哈希值。這個(gè)動(dòng)作將創(chuàng)世塊與第2塊聯(lián)系起來(lái)!接下來(lái),我們將時(shí)間戳,交易列表和先前的哈希值作為我們的哈希算法的輸入。該算法將為我們提供一個(gè)新的哈希值來(lái)表示塊2。
我們將繼續(xù)重復(fù)該過(guò)程任意多次,除了區(qū)塊的有效性以及存儲(chǔ)區(qū)塊鏈的能力(比特幣的區(qū)塊鏈約為330 GB)之外,沒(méi)有任何其他限制。
在Go中創(chuàng)建一個(gè)簡(jiǎn)單的區(qū)塊鏈
創(chuàng)建我們的區(qū)塊鏈的第一步是定義什么是區(qū)塊。Go使我們的生活更輕松地創(chuàng)建自定義類(lèi)型,我們可以Block使用以下代碼來(lái)定義類(lèi)型。在這里,該Block結(jié)構(gòu)具有四個(gè)字段以匹配我們上面的圖。
type Block struct { timestamp time.Time transactions []string prevHash []byte Hash []byte}
下一步是創(chuàng)建構(gòu)造函數(shù)的Go版本,以創(chuàng)建新的塊。該函數(shù)的輸入將使用一個(gè)字符串?dāng)?shù)組來(lái)表示事務(wù),以及一個(gè)字節(jié)數(shù)組來(lái)表示先前制作的塊所對(duì)應(yīng)的先前的哈希值。下一個(gè)要研究的NewHash()功能是我們下一步將實(shí)現(xiàn)的功能。
func NewBlock(transactions []string, prevHash []byte) *Block { currentTime := time.Now() return &Block { timestamp: currentTime, transactions: transactions, prevHash: prevHash, Hash: NewHash(currentTime, transactions, prevHash), }}
該NewHash()函數(shù)將時(shí)間,事務(wù)列表和以前的哈希作為我們的輸入?yún)?shù),同時(shí)返回一個(gè)字節(jié)數(shù)組來(lái)表示新生成的哈希值。在此功能中,我們基本上只是將所有輸入都混入一個(gè)稱(chēng)為的單個(gè)字節(jié)數(shù)組中input。我們這樣做是使用append()功能的附加time參數(shù),prevHash通過(guò)轉(zhuǎn)換time為string用...,以追加作為后綴time片的prevHash切片。
然后,我們遍歷transactions并將每個(gè)個(gè)體附加transaction到input數(shù)據(jù)blob。有趣的語(yǔ)法string(rune(transaction))...只是Go中將其中的每個(gè)元素轉(zhuǎn)換transactions為可以附加到的切片的一種方法input。它正在輸入垃圾內(nèi)容,因此,如果您真的想要,請(qǐng)深入研究。
func NewHash(time time.Time, transactions []string, prevHash []byte) []byte { input := append(prevHash, time.String()...) for transaction := range transactions { input = append(input, string(rune(transaction))...) } hash := sha256.Sum256(input) return hash[:]}
最后,我們使用crypto包轉(zhuǎn)到電話(huà)sha256.Sum256()與input作為它的參數(shù)。這將為我們的所有數(shù)據(jù)輸入提供新的哈希表示。我們返回時(shí)hash[:]使用的[:]語(yǔ)法將hash在返回時(shí)切成適當(dāng)?shù)拈L(zhǎng)度。
這實(shí)際上是我們開(kāi)始鏈接我們的區(qū)塊鏈所需的全部。當(dāng)然,我們希望在程序中看到某種輸出,以便在打印時(shí)可以使用一些輔助方法:
func printBlockInformation(block *Block) { fmt.Printf("\ttime: %s\n", block.timestamp.String()) fmt.Printf("\tprevHash: %x\n", block.prevHash) fmt.Printf("\tHash: %x\n", block.Hash) printTransactions(block)}func printTransactions(block *Block) { fmt.Println("\tTransactions:") for i, transaction := range block.transactions { fmt.Printf("\t\t%v: %q\n", i, transaction) }}
現(xiàn)在剩下的就是創(chuàng)建新的事務(wù),塊和哈希。我們可以通過(guò)我們的主要方法來(lái)做到這一點(diǎn)。我們定義了一個(gè)字符串?dāng)?shù)組來(lái)記錄我們的區(qū)塊鏈中的交易。另請(qǐng)注意,我們?nèi)绾蝹鬟f一個(gè)空字節(jié)數(shù)組NewBlock()來(lái)生成名為的第一個(gè)塊genesisBlock。
func main() { genesisTransactions := []string{"Izzy sent Will 50 bitcoin", "Will sent Izzy 30 bitcoin"} genesisBlock := NewBlock(genesisTransactions, []byte{}) fmt.Println("--- First Block ---") printBlockInformation(genesisBlock) block2Transactions := []string{"John sent Izzy 30 bitcoin"} block2 := NewBlock(block2Transactions, genesisBlock.Hash) fmt.Println("--- Second Block ---") printBlockInformation(block2) block3Transactions := []string{"Will sent Izzy 45 bitcoin", "Izzy sent Will 10 bitcoin"} block3 := NewBlock(block3Transactions, block2.Hash) fmt.Println("--- Third Block ---") printBlockInformation(block3)}
為了創(chuàng)建新的區(qū)塊,我們將前一個(gè)區(qū)塊的哈希值NewBlock()與對(duì)應(yīng)的交易歷史記錄一起傳遞。如果您想在一個(gè)地方查看整個(gè)程序,則為:
package mainimport ( "crypto/sha256" "fmt" "time")type Block struct { timestamp time.Time transactions []string prevHash []byte Hash []byte}func main() { genesisTransactions := []string{"Izzy sent Will 50 bitcoin", "Will sent Izzy 30 bitcoin"} genesisBlock := NewBlock(genesisTransactions, []byte{}) fmt.Println("--- First Block ---") printBlockInformation(genesisBlock) block2Transactions := []string{"John sent Izzy 30 bitcoin"} block2 := NewBlock(block2Transactions, genesisBlock.Hash) fmt.Println("--- Second Block ---") printBlockInformation(block2) block3Transactions := []string{"Will sent Izzy 45 bitcoin", "Izzy sent Will 10 bitcoin"} block3 := NewBlock(block3Transactions, block2.Hash) fmt.Println("--- Third Block ---") printBlockInformation(block3)}func NewBlock(transactions []string, prevHash []byte) *Block { currentTime := time.Now() return &Block { timestamp: currentTime, transactions: transactions, prevHash: prevHash, Hash: NewHash(currentTime, transactions, prevHash), }}func NewHash(time time.Time, transactions []string, prevHash []byte) []byte { input := append(prevHash, time.String()...) for transaction := range transactions { input = append(input, string(rune(transaction))...) } hash := sha256.Sum256(input) return hash[:]}func printBlockInformation(block *Block) { fmt.Printf("\ttime: %s\n", block.timestamp.String()) fmt.Printf("\tprevHash: %x\n", block.prevHash) fmt.Printf("\tHash: %x\n", block.Hash) printTransactions(block)}func printTransactions(block *Block) { fmt.Println("\tTransactions:") for i, transaction := range block.transactions { fmt.Printf("\t\t%v: %q\n", i, transaction) }}
如果要運(yùn)行此程序,將得到以下輸出:
$ go run example.go --- First Block --- time: 2021-04-05 15:12:18.813294 -0600 MDT m=+0.000074939 prevHash: Hash: 43ec51c50d2b9565f221155a29d8b72307247b08eaf6731cca Transactions: 0: "Izzy sent Will 50 bitcoin" 1: "Will sent Izzy 30 bitcoin"--- Second Block --- time: 2021-04-05 15:12:18.813477 -0600 MDT m=+0.000257244 prevHash: 43ec51c50d2b9565f221155a29d8b72307247b08eaf6731cca Hash: fcce5323a35cb67b45fe75866582db00fd32baeb92aac448c7 Transactions: 0: "John sent Izzy 30 bitcoin"--- Third Block --- time: 2021-04-05 15:12:18.813488 -0600 MDT m=+0.000269168 prevHash: fcce5323a35cb67b45fe75866582db00fd32baeb92aac448c7 Hash: fc1d3eee286970d85812b47c3a5bf016ae8c1de4f86b8ace972ffa Transactions: 0: "Will sent Izzy 45 bitcoin" 1: "Izzy sent Will 10 bitcoin"
過(guò)程可能會(huì)很粗糙,但這是創(chuàng)建自己的區(qū)塊鏈的基礎(chǔ)!
以上就是GO創(chuàng)建區(qū)塊鏈,怎么用GO實(shí)現(xiàn)一個(gè)簡(jiǎn)單的區(qū)塊鏈?的詳細(xì)內(nèi)容,更多關(guān)于GO創(chuàng)建區(qū)塊鏈的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
你可能感興趣的文章
-
以太坊還能漲嗎?從技術(shù)和基本面幫你看懂真相
上一周以太坊實(shí)現(xiàn)26.4%的周漲幅, 一舉突破2800的壓力位, 沖刺至4000大關(guān)腳下,以太坊還能漲嗎?下文將從以太坊的基本面以及技術(shù)面價(jià)格走勢(shì)來(lái)分析過(guò)去一周以及今年以來(lái)的以太…
2025-07-28 -
區(qū)塊鏈究竟是什么?原理、應(yīng)用、投資風(fēng)險(xiǎn)以及未來(lái)趨勢(shì)解析
區(qū)塊鏈究竟是什么?區(qū)塊鏈簡(jiǎn)單說(shuō),就是一種建立在線上的去中心化的數(shù)位帳本技術(shù),能確保交易數(shù)據(jù)安全透明,且不可篡改,這種技術(shù)不僅應(yīng)用于比特幣,還被廣泛應(yīng)用于供應(yīng)鏈管…
2025-07-28 -
加密貨幣中鏈上與鏈下交易主要區(qū)別是什么?
加密領(lǐng)域的鏈上交易是指直接在區(qū)塊鏈上執(zhí)行的轉(zhuǎn)賬,鏈下交易最初繞過(guò)區(qū)塊鏈驗(yàn)證,最終確認(rèn)后再記錄在鏈上,從而提高速度并降低成本,鏈下流程的用戶(hù)允許受信任的第三方處理交…
2025-07-28 -
ChatGPT怎么用?ChatGPT AI 在加密交易中的5 個(gè)實(shí)際應(yīng)用案例
加密貨幣交易面臨獨(dú)特的挑戰(zhàn):海量的數(shù)據(jù)流、迅速的市場(chǎng)變動(dòng)和情緒決策陷阱,雖然技術(shù)分析和基本面研究依然至關(guān)重要,但現(xiàn)在許多交易者已經(jīng)開(kāi)始利用像ChatGPT 這樣的AI 工具…
2025-07-28 -
什么是Linea?如何運(yùn)作?ConsenSys 推出的以太坊Layer-2 網(wǎng)絡(luò)?
什么是Linea?如何運(yùn)作?作為第二大公有區(qū)塊鏈,以太坊's 網(wǎng)絡(luò)仍然面臨著高昂的Gas 費(fèi)用、慢速交易速度和有限的吞吐量,尤其是在需求高峰時(shí),進(jìn)入Linea,一個(gè)由以太坊Layer-…
2025-07-28 -
什么是云算力?如何運(yùn)作?挖礦加密貨幣的簡(jiǎn)單指南
在不斷發(fā)展的加密貨幣世界中,挖礦長(zhǎng)期以來(lái)被視為推動(dòng)區(qū)塊鏈網(wǎng)絡(luò)的最基本過(guò)程之一,然而,隨著挖礦變得越來(lái)越具競(jìng)爭(zhēng)性和資源密集型,許多人開(kāi)始轉(zhuǎn)向一種更為便捷的替代方案…
2025-07-28 -
TRON是什么?最快、最便宜的USDT網(wǎng)絡(luò)的構(gòu)建介紹
2025年7月,波場(chǎng)TRON掀起波瀾,其原生代幣TRX一度超越卡爾達(dá)諾的ADA,成為市值第九大的加密貨幣,這一里程碑不僅體現(xiàn)在波場(chǎng)TRON市值飆升至298億美元,還體現(xiàn)在該公司在納斯…
2025-07-28 -
什么是去中心化應(yīng)用 (dApp)?dApp的優(yōu)勢(shì)、缺點(diǎn)、用途是什么介紹
去中心化應(yīng)用程序dApps是在點(diǎn)對(duì)點(diǎn)P2P或區(qū)塊鏈網(wǎng)絡(luò)上運(yùn)行的軟件,而不是在單個(gè)服務(wù)器或集中式計(jì)算機(jī)上運(yùn)行,在區(qū)塊鏈技術(shù)和智能合約的支持下,dApp提供了增強(qiáng)的安全性、透明…
2025-07-28 -
Monad是什么?Monad主網(wǎng)發(fā)布日期和空投是什么時(shí)候?
Monad是一個(gè)高性能 Layer1區(qū)塊鏈,旨在徹底革新以太坊兼容性,Monad的主網(wǎng)發(fā)布日期為2025年9月30日,代幣指標(biāo)如下:MON的總發(fā)行量和最大發(fā)行量均為1000億,盡管 Monad Labs尚…
2025-07-27 -
正向合約和反向合約是什么??jī)烧哂惺裁磪^(qū)別?各有什么優(yōu)勢(shì)?
在永續(xù)合約市場(chǎng)中,合約一般分為正向合約和反向合約,正向合約在加密市場(chǎng)中也稱(chēng)為USDT本位合約、穩(wěn)定幣合約,它以USDT為定價(jià)單位,而反向合約也稱(chēng)為幣本位合約,反向合約則是…
2025-07-26