区块链技术基础(笔记)

一、区块链本质上是一个对等网络(peer-to-peer)的分布式账本数据库。

二、区块链本身其实是一串链接的数据区块,其链接 指针是采用密码学哈希算法对区块头进行处理所产生的区块头哈希值。

三、基本概念

1、 数据区块:

    比特币的交易会保存在数据区块中,大约每10分钟会产生一个区块,每个数据区块一般包括区块头(Header)和区块体(Body)两部分。

    

    区块体中则主要包含交易计数和交易详情。

 

    交易详情就是比特币系统中的记账本,每一笔交易都会被永久地记入数据区块中,并且所有人都可以查看。

 

    区块体中的Merkle树将会对每一笔交易进行数字签名,如此可以确保每一笔交易都不可伪造且没有重复交易。

    所有的交易将通过Merkle树的Hash过程产生一个唯一Merkle根值记入区块头。

 

2、挖矿与分叉问题

3、时间戳和不可篡改性

    在比特币系统中,获得记账权的节点在链接节点时需要在区块头中加盖时间戳,用于记录当前区块数据的写入时间。每一个随后区块中的时间戳都会对-前一个时间戳进行增强,形成一个时间递增的链条。时间戳可以作为存在性证明(Proof of existence)的重要参数。

4、分布式数据库

5、UTXO交易模式

    未花费交易输出,是比特币交易过程中的基本单位。

6、哈希函数

7、Merkle树

    比特币区块链系统中采用的是Merkle二叉树。优点:极大的提高了区块链的运行效率和可扩展性。使得区块头只需包含根哈希值而不必封装所有底层数据,这使得哈希运算可以高速地运行在智能手机和物联网设备上;其次是Merkle树可支持“简化支付验证协议”(SPV),即在不运行完整区块链网络节点的情况下,也能够对交易数据进行验证。

    

 

8、双重支付(双花问题)

    利用货币的数字特征用“同一笔钱”完成两次或者多次支付。区块链技术通过区块链接形成的时间戳技术加上验证比特币是否满足UTXO和数字签名,有效的避免了双花问题。

9、P2P网络

10、加密算法

    除了哈希算法外,还存在一种为交易加密的非对称加密算法(椭圆曲线加密算法)。非对称加密算法指的是存在一对数学相关的秘钥,使用其中一个秘钥进行加密的数据信息,只能使用另一个秘钥才能对该信息进行解密。这对秘钥中,对外公开的秘钥叫公钥,不公开的秘钥叫私钥。

    比特币系统一般从操作系统底层的一个密码学安全的随机源中取出一个256位随机数作为私钥,私钥总数为2*256 个,所以很难通过遍历所有可能的私钥得出与公钥的对应的私钥。用户使用的私钥还会通过SHA256和Base58转换成易书写和识别的50位长度的私钥,公钥则首先由私钥和Secp256k1椭圆曲线算法生成65字节长度的随机数。

    

  • 2
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值