当前位置:主页 > 区块链 > 区块链技术 > GO创建区块链

GO创建区块链,怎么用GO实现一个简单的区块链?

2021-04-19 16:18:13 | 来源:比特范 | 作者:佚名
这篇文章主要介绍了GO创建区块链,怎么用GO实现一个简单的区块链?本文中,我们将使用2021年最流行的编程语言之一GoLang实现基本的区块链。下面跟随小编一起来参考下内容吧!

自互联网以来,锁链技术已被某些人称为最有影响力的发明。尽管公众将区块链与投机性加密货币同义解释,但区块链实际上在现代世界中具有不可思议的广泛应用。实际上,加密货币只是区块链领域的一小部分,生产中的许多解决方案都是由私人组织领导来实现的。

GO创建区块链,怎么用GO实现一个简单的区块链?

随着区块链技术的迅速发展,技术领域的专业人员越来越需要了解区块链的基础知识及其技术影响力。

毕竟,实现自己的区块链实际上并不像听起来那样复杂。本文中,我们将使用2021年最流行的编程语言之一GoLang实现基本的区块链。那么,让我们开始吧!

了解区块链

区块链是名称符合其含义的少数技术之一。我们可以将区块链视为通过哈希相互连接的信息块,哈希是从输入数据生成的加密的固定输出。由于每个块都通过哈希相互引用,因此如果不大幅度更改链的其余部分,就不可能更改链的任何部分。

区块链中的每个块都可以包含几乎任何内容的数据。一个基本框架将包括每个块的过去交易的所有记录。比特币以类似的方式工作,这就是为什么您可以一直跟踪比特币交易直至Satoshi首次进行加密货币交易的原因。

下面我们有三个区块来创建区块链。第一块是创世块。由于之前没有任何内容,因此前一个哈希字段为空。我们仍然使用时间戳记属性和初始事务作为哈希算法的输入。该算法将吐出一大串数字和字母,这些数字和字母代表了创世纪块的哈希值。

 

转到块2,我们将创世块的哈希值用作块2先前哈希值。这个动作将创世块与第2块联系起来!接下来,我们将时间戳,交易列表和先前的哈希值作为我们的哈希算法的输入。该算法将为我们提供一个新的哈希值来表示块2。

我们将继续重复该过程任意多次,除了区块的有效性以及存储区块链的能力(比特币的区块链约为330 GB)之外,没有任何其他限制。

在Go中创建一个简单的区块链

创建我们的区块链的第一步是定义什么是区块。Go使我们的生活更轻松地创建自定义类型,我们可以Block使用以下代码来定义类型。在这里,该Block结构具有四个字段以匹配我们上面的图。

type Block struct { timestamp time.Time transactions []string prevHash []byte Hash []byte}

下一步是创建构造函数的Go版本,以创建新的块。该函数的输入将使用一个字符串数组来表示事务,以及一个字节数组来表示先前制作的块所对应的先前的哈希值。下一个要研究的NewHash()功能是我们下一步将实现的功能。

func NewBlock(transactions []string, prevHash []byte) *Block { currentTime := time.Now() return &Block { timestamp: currentTime, transactions: transactions, prevHash: prevHash, Hash: NewHash(currentTime, transactions, prevHash), }}

该NewHash()函数将时间,事务列表和以前的哈希作为我们的输入参数,同时返回一个字节数组来表示新生成的哈希值。在此功能中,我们基本上只是将所有输入都混入一个称为的单个字节数组中input。我们这样做是使用append()功能的附加time参数,prevHash通过转换time为string用...,以追加作为后缀time片的prevHash切片。

然后,我们遍历transactions并将每个个体附加transaction到input数据blob。有趣的语法string(rune(transaction))...只是Go中将其中的每个元素转换transactions为可以附加到的切片的一种方法input。它正在输入垃圾内容,因此,如果您真的想要,请深入研究。

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包转到电话sha256.Sum256()与input作为它的参数。这将为我们的所有数据输入提供新的哈希表示。我们返回时hash[:]使用的[:]语法将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) }}

现在剩下的就是创建新的事务,块和哈希。我们可以通过我们的主要方法来做到这一点。我们定义了一个字符串数组来记录我们的区块链中的交易。另请注意,我们如何传递一个空字节数组NewBlock()来生成名为的第一个块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)}

为了创建新的区块,我们将前一个区块的哈希值NewBlock()与对应的交易历史记录一起传递。如果您想在一个地方查看整个程序,则为:

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) }}

如果要运行此程序,将得到以下输出:

$ 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"

过程可能会很粗糙,但这是创建自己的区块链的基础!

以上就是GO创建区块链,怎么用GO实现一个简单的区块链?的详细内容,更多关于GO创建区块链的资料请关注脚本之家其它相关文章!

免责声明:本文只为提供市场讯息,所有内容及观点仅供参考,不构成投资建议,不代表本站观点和立场。投资者应自行决策与交易,对投资者交易形成的直接或间接损失,作者及本站将不承担任何责任。!
Tag:GO   区块链   Golang  

你可能感兴趣的文章

更多

热门币种

  • 币名
    最新价格
    24H涨幅
  • bitcoin BTC 比特币

    BTC

    比特币

    $ 71488.83¥ 493022.71
    +7.36%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 2078.83¥ 14336.65
    +6.59%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 0.9999¥ 6.8958
    +0.02%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 652.37¥ 4499.06
    +4.82%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.4069¥ 9.7026
    +4.66%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 0.9996¥ 6.8937
    -0.04%
  • solana SOL Solana

    SOL

    Solana

    $ 90.1129¥ 621.46
    +7.22%
  • tron TRX 波场

    TRX

    波场

    $ 0.2835¥ 1.9551
    +0.89%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.092746¥ 0.6396
    +3.67%
  • hyperliquid HYPE Hyperliquid

    HYPE

    Hyperliquid

    $ 32.4168¥ 223.56
    +1.63%

币圈快讯

  • 2380万枚WLFI从匿名地址转出经中转后流入Bitget

    2026-03-04 19:12
    据Arkham数据,在19:04,2380万枚WLFI(价值约251.98万美元)从一匿名地址(0xCA6E...开头)转出至另一匿名地址(0x7292...开头)。随后,该地址将部分WLFI转移至Bitget。
  • Bybit即将上线Opinion(OPN)现货交易

    2026-03-04 19:11
    据官方消息,Bybit将在现货专区上线Opinion(OPN)。 Opinion(OPN)是一个链上预测交易所(predictionexchange),允许用户直接将宏观经济数据、预测事件和新闻作为标准化资产进行交易。
  • FATF:稳定币现主导非法加密资金流动P2P交易成监管盲区

    2026-03-04 19:06
    据Cointelegraph报道,国际反洗钱监管机构金融行动特别工作组(FATF)在最新报告中指出,通过自托管钱包进行的点对点(P2P)稳定币转账已成为加密货币生态系统中的关键弱点,因其可绕过反洗钱(AML)监管。FATF强调,这类交易无需通过受监管中介机构即可完成,造成监管缺口。报告显示,2025年稳定币占非法交易总量的84%,成为规避制裁等非法活动的主要工具。虽然区块链交易可追踪,但钱包地址的匿名性增加了归因难度。FATF呼吁各国评估稳定币安排带来的风险,并采取相称的缓解措施,包括加强自托管钱包与受监管平台交互时的监控,以及明确稳定币发行和分销实体的反洗钱义务。
  • 2380万枚WLFI从匿名地址转出经中转后转至另一匿名地址

    2026-03-04 19:02
    据Arkham数据,在18:56,2380万枚WLFI(价值约2521万美元)从一匿名地址(0x0596...开头)转出至另一匿名地址(0xf7A6...开头)。随后,该地址将2380万枚WLFI转移至另一匿名地址(0xCA6E...开头)。
  • BinanceWallet现已深度集成RootData数据

    2026-03-04 19:01
    BinanceWallet在最近的更新中深度集成RootData数据,用户现在可以在该钱包内查看项目的介绍、融资、团队成员、日历等数据,从而使用户在投资时更加清晰、准确地了解项目信息,降低信息壁垒与噪音。目前,RootDataAPI的累计合作伙伴已经超过200家,包括以太坊基金会、OKXWallet、CertiK、Gate、Blockworks、CMTDigital、AmberGroup、TechFlow、BlockBeats、MaskNetwork、TokenPocket等覆盖众多场景的诸多知名项目。
  • 查看更多