区块链实战(一)实现简单的区块与区块链交易

简介: 区块链实战(一)实现简单的区块与区块链交易

区块链实战

image.png

**注意:**区块不存储hash值,节点接受区块后独立计算并存储在本地。


Version 1

区块相关:

1.定义一个区块的结构Block


a.区块头:6个字段


b.区块体:字符串表示data


提供一个创建区块的方法


NewBlock(参数)


区块链相关

定义一个区块链结构BlockChain


Block数组


提供一个创建BlockChain()的方法

NewBlockChain()


提供一个添加区块的方法

AddBlock(参数)


block.go文件

package main
import (
  "bytes"
  "crypto/sha256"
  "time"
)
/*
1.定义一个区块的结构Block
​a.区块头:6个字段
​b.区块体:字符串表示data
*/
//区块
type Block struct {
  Version int64   //版本
  PerBlockHash []byte //前一个区块的hash值
  Hash []byte //当前区块的hash值,是为了简化代码
  MerKelRoot []byte  //梅克尔根
  TimeStamp int64  //时间抽
  Bits int64  //难度值
  Nonce int64 //随机值
//区块体
  Data []byte  //交易信息
}
/*
提供一个创建区块的方法
NewBlock(参数)
*/
func NewBlock(data string ,prevBlockHash []byte) *Block {
  var block Block
  block = Block{
    Version:      1,
    PerBlockHash: prevBlockHash,
    //Hash:         []byte{},     //区块不存储hash值,节点接受区块后独立计算并存储在本地。
    MerKelRoot:   []byte{},
    TimeStamp:    time.Now().Unix(),
    Bits:         1,
    Nonce:        1,
    Data:         []byte(data),
  }
  block.SetHash()  //填充Hash
  return &block
}
func (block *Block) SetHash() {
  // 源码里面是要传二维切片 func Join(s [][]byte, sep []byte) []byte
  tmp :=[][]byte{
    IntToByte(block.Version),
    block.PerBlockHash,
    block.MerKelRoot,
    IntToByte(block.TimeStamp),
    IntToByte(block.Bits),
    IntToByte(block.Nonce),
  }
  data:=bytes.Join(tmp,[]byte{})    //之后再计算hash
  hash := sha256.Sum256(data)
  block.Hash = hash[:]  //变切片
}
//创始块
func NewGensisBlock() *Block{
  return NewBlock("Genesis Block!",[]byte{})
}

blockChain.go文件

package main
/*
1. 定义一个区块链结构BlockChain
   Block数组
*/
type BlockChain struct {
   blocks []*Block
}
/*
2. 提供一个创建BlockChain()的方法
   NewBlockChain()
*/
func NewBlockChain() *BlockChain {
   block := NewGensisBlock()
   return &BlockChain{blocks:[]*Block{block}}  //创建只有一个元素的区块链,初始化
}
/*
3. 提供一个添加区块的方法
   AddBlock(参数)
*/
func (bc *BlockChain)AddBlock(data string)  {
   PerBlockHash := bc.blocks[len(bc.blocks)-1].Hash  //这一个区块的哈希是前一块的哈希值
   block := NewBlock(data,PerBlockHash)
   bc.blocks = append(bc.blocks,block)
}

utils.go文件

package main
import (
   "bytes"
   "encoding/binary"
   "fmt"
   "os"
)
func IntToByte(num int64) []byte {
   //func Write(w io.Writer, order ByteOrder, data interface{}) error {
   var buffer bytes.Buffer
   err := binary.Write(&buffer, binary.BigEndian, num)
   CheckErr("IntToByte",err)
   return buffer.Bytes()
}
func CheckErr(position string,err error) {
   if err != nil {
      fmt.Println("error ,pos:",position,err)
      os.Exit(1)
   }
}

main.go文件

package main
import "fmt"
func main() {
   bc := NewBlockChain()
   bc.AddBlock("A send B 1BTC")
   bc.AddBlock("B send C 1BTC")
   for _,block := range bc.blocks {
      fmt.Printf("Version : %d\n",block.Version)
      fmt.Printf("PerBlockHash : %x\n",block.PerBlockHash)
      fmt.Printf("Hash : %x\n",block.Hash)
      fmt.Printf("MerKelRoot : %x\n",block.MerKelRoot)
      fmt.Printf("TimeStamp : %d\n",block.TimeStamp)
      fmt.Printf("Bits : %d\n",block.Bits)
      fmt.Printf("Nonce : %d\n",block.Nonce)
      fmt.Printf("Data : %s\n",block.Data)
   }
}

执行结果

image.png

相关文章
|
6月前
|
存储 供应链 安全
【区块链】智能交易模式下的数据安全流通模型
【区块链】智能交易模式下的数据安全流通模型
365 1
|
6月前
|
安全 数据挖掘 API
《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)(下)
《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)(下)
135 1
|
6月前
|
数据可视化 数据挖掘 区块链
《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)(上)
《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)(上)
288 0
|
5月前
|
存储 供应链 安全
区块链技术防止交易被篡改的能力主要依赖于其独特的架构和机制
**区块链技术通过分布式存储、去中心化网络、哈希链接、共识机制及加密算法确保交易防篡改。每个区块含前块哈希,篡改将破坏链式结构;共识机制如PoW、PoS保证交易验证;智能合约增强安全性。多层防护保障数据完整性和安全性,支撑其在多个行业中的应用。**
|
5月前
|
算法 安全 区块链
区块链如何实现交易匿名性
**区块链匿名性摘要:** - 匿名性源于公钥/私钥系统,公钥作地址,私钥验证交易,不透露身份信息。 - Coin Mixing 和 CoinJoining 混合交易,使资金流向难以追踪。 - 匿名币如 Monero、Zcash 使用零知识证明和环签名技术增强匿名。 - 隐身地址和一次性地址增加隐私,公私钥交换确保安全交易而不暴露身份。 - 多层次加密与协议结合,保障区块链交易隐私。
|
5月前
|
供应链 监控 区块链
区块链如何确保供应链交易的透明度
**区块链提升供应链透明度:** 创建不可篡改交易记录,确保数据真实完整;实时监控各个环节,增强状态可见性;追踪产品全生命周期,消费者可追溯源头;共享信息平台减少欺诈,提高协同效率与诚信度。这些机制打造透明、可信的供应链网络。
|
供应链 安全 区块链
【论文复现】基于区块链的分布式光伏就地消纳交易模式研究(Matlab代码实现)
【论文复现】基于区块链的分布式光伏就地消纳交易模式研究(Matlab代码实现)
134 0
|
区块链
区块链101:区块链交易是如何运作的?
区块链101:区块链交易是如何运作的?
|
安全 算法 区块链
区块链金融交易借贷平台开发技术实现去中心化
传统的金融交易清算周期长和成本高昂,引入区块链技术,能够加快传统金融交易中心化的交易缓慢和低效的后端运作,并且重塑交易和结算流程。一个共享的数字公开账本能够持续被维护,确认所有参与链上的交易,防止欺诈,对全球金融交易、清算和结算带来了一个重大的改观机会。
|
存储 机器学习/深度学习 人工智能
【源码亲测演示】火币虚拟币交易平台币币交易区块链虚拟
花火交易所搭建 合作搭建交易所 仿28交易所搭建 如何搭建货币交易所 交易所源码搭建教程 怎么搭建usdt交易所 交易所搭建数字货币 杭州交易所搭建源码 搭建交易所教程 合约交易所如何搭建 交易所和平台搭建 怎么搭建交易所
【源码亲测演示】火币虚拟币交易平台币币交易区块链虚拟

热门文章

最新文章