bitcoin轻钱包之SPV验证

这篇具有很好参考价值的文章主要介绍了bitcoin轻钱包之SPV验证。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

SPV验证

在bitcoin中被首次使用,本文就针对bitcoin中的SPV验证来介绍。

区块结构

  • 区块头header+区块体body
  • 区块头:版本号、随机数、挖矿难度、前一个区块的哈希、Merkle根(交易列表计算而成的)
  • 区块体:交易列表

轻客户端

全节点( Full Node )和轻客户端( Thin Client ):全节点是一个程序,例如中本聪自己写的 Bitcoin Coin ,这个程序运行起来之后,会把整条区块链都下载到本地。目前(2022年中),bitcoin所有区块大小总和已经达到几百G,要在手机上跑全节点基本是不可能的。所以有轻客户端的概念,例如 Electrum 就是个轻客户端。轻客户端可以安装在电脑上也可以安装在手机上,为啥呢?因为轻客户端只会去下载区块头,每个区块头只有80K,所以一条区块头组成的链,只有几十兆。

SPV 就是一个在轻客户端环境下,验证交易有效性的过程。

SPV验证过程

安装全节点,很多时候是因为我们要挖矿。而安装轻客户端,通常就是把它当成一个钱包软件用。SPV 要解决的就是使用轻客户端交易时的支付确认问题

钱包当然就是用来负责当前账户的转入和转出操作的。先说转出,**轻客户端能构建交易,并且签名交易,再广播到全网。再说转入,网上交易很多,但是轻客户端只会去下载跟自己的账户相关的交易。**那么不管是转入还是转出交易,下载到轻客户端本地的都是相对孤立的交易,因为本地没有保存区块体。那么如何去验证交易生效了呢?这就是 SPV 要解决的问题。我们知道,一个交易在区块链上生效,意味着要满足两个条件:一个是交易已经被打包到了某个区块中,另外一个是这个区块之上又继续打包了5个区块,也就是所谓的六次确认。

但是,毕竟轻客户端这里是没有保存任何交易的,所以一个独立的交易拿出来,要确定它属于哪个区块也是不可能的。这时候轻客户端需要发起 SPV 过程

1、首先,轻客户端要发起一个专门的确认请求,把这个交易广播给网络上邻近的全节点

2、全节点收到交易后,会去搜索这个交易属于哪个区块,然后会运算这个区块的 Merkle Tree

这时, Merkle Tree 最大的优势现在就发挥出来了,因为要确认一个交易是不是从属于一个 Merkle 根,是不需要把整个 Merkle Tree 都发送给轻节点的,而只需要发送跟当前交易相关的部分 Merkle 树即可。

3、这样,轻节点接收到这个局部的 Merkle 树之后,在自己本地运算一下这个交易的哈希,然后根据部分 Merkle 树上的各个哈希值,一路运算获得 Merkle 根,如果这个值跟自己的区块头中的正好吻合,交易验证就成功了

总结来说,轻节点想要确认本地保存的某交易,是否被打包进区块链,需要触发SPV验证过程,过程如下:

  1. 轻节点向邻近所有全节点发送SPV确认请求request
  2. 全节点在区块链中搜索request中包含的交易t所在区块b
  3. 全节点计算区块b的Merkle树
  4. 全节点发送部分Merkle树给轻节点
  5. 轻节点根据这部分树和t计算出来一个Merkle根root1
  6. 轻节点比较root1和本地保存的区块头中的merkle根,若相同说明t已经被包含在区块链中

所以整个 SPV 过程是靠全节点帮忙去验证交易的,轻节点自身不能验证交易,但是通过确认其他全节点都接受了这次交易,就间接完成了交易确认。但是,全节点有没有可能反馈一个假的 Merkle Tree 过来呢?答案是不可能。反馈一个假的,不可能骗到用户,因为和用户本地的merkle root根本不会一样。想要伪造成功,就是去碰撞 sha256 算法,这是计算不可能实现的。

SPV 有什么用处?

首先一个用处就是实现钱包软件。如果一个钱包软件想要安装在移动设备上,想要避免去下载一百多 G 的区块数据。那么就只有两个思路,一个是借助中心化服务器,让钱包去把信息先发送到服务器,然后由服务器去验证交易,这样的思路显然就偏中心化了。另外一个思路就是 SPV ,类似 Electrum 这样的钱包,就可以通过只下载区块头来验证交易,整个的数据量和计算量都是不大的,可以直接运行在低端设备上。所以很多轻客户端,也叫轻钱包,或者叫 SPV 钱包。

SPV 的另外一个用途就是实现侧链技术。侧链就是可以通过双向锚定来使用主链上的币的一条链,上面可以做出各种创新。例如基于bitcoin的侧链开发出的 RootStock ,可以基于bitcoin实现智能合约平台。而双向锚定过程,就依赖于 SPV 技术。

所以,虽然 SPV 在白皮书上所占的篇幅不大,但是实际中发挥的作用是非常大的。

总结

第一,区块由区块头和区块体组成,区块头中的前一个区块的哈希,其实就是之前一个区块的区块头的哈希,所以单独下载区块头,也能得到一条链。

第二,同样是bitcoin网络上的节点,却可以分成全节点和轻客户端两类,轻客户端就是只下载了区块头。

第三,SPV 解决的就是在轻客户端中去确认单独一个交易的过程,总体思路是去相邻的全节点中去请求部分 Merkle 树信息,到本地验证通过,就证明其他的全节点都接受了这个交易。

第四,SPV 是开发钱包软件和侧链的关键技术,意义非常重大。文章来源地址https://www.toymoban.com/news/detail-790532.html

到了这里,关于bitcoin轻钱包之SPV验证的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 比特币/以太坊/加密货币/网络/区块链/钱包助记词:密码学的角度上,24个单词比12个单词更安全吗

    我们从密码学角度来聊聊助记词。 随着区块链钱包的发展和分层确定性(HD)钱包技术的普及,越来越多的用户开始熟悉了一个叫“助记词”的概念,很多人都已经习惯了从一开始使用一个钱包的时候,就先抄好单词认真保管,并且他们对于助记词的重要性也有了很深刻的理

    2024年02月12日
    浏览(53)
  • 如何在比特币上验证ZK Proofs

    前序博客有: 基于BitVM的乐观 BTC bridge BitVM:Bitcoin的链下合约 Bitcoin Bridge:治愈还是诅咒? BitVM2:比特币上的无需许可验证 以比特币脚本来实现SNARK Verifier Clementine:Citrea的基于BitVM的信任最小化双向bridge 要点: 1)若有OP_CAT,Merkle path验证将更容易 2)sCrypt团队在Bitcoin SV 上

    2024年04月09日
    浏览(69)
  • Web3钱包和身份验证:安全和去中心化的新标准

    在数字化的今天,我们正处于一个互联网技术迅速发展的时代。Web3作为一个革命性的概念,正在逐渐改变我们对互联网的看法和使用习惯。在这一变革中,Web3钱包和身份验证成为了核心组成部分,它们不仅为我们提供了安全和去中心化的解决方案,还重新定义了在线身份、

    2024年04月28日
    浏览(31)
  • 比特币是怎么回事?

    比特币是怎么回事? 一句话描述就是,初始化几个比特币,申请成为矿工组织,发生交易时抢单记账成功可以获得比特币奖励,随着比特币数量的增加,奖励越来越少。怎么记账成功呢,通过交易信息+幸运数字哈希算法得到一个满足条件的账单编号。显卡简单算术单元很多

    2024年02月11日
    浏览(32)
  • CEX暴雷怎么办 一文读懂加密钱包产业现状

    你的钱其实并不在你的借记卡里,借记卡只是授权你的银行帐户向银行系统数据库发送交易。同样,你的代币也并不在你的加密钱包里。加密钱包只是持有私有密钥以证明对数字资产的所有权,而这些资产是存储在公共区块链网络上的。私钥能让你对加密钱包交易进行授权。

    2024年02月02日
    浏览(37)
  • vue2 Elementui 树形组件怎么实现多选并获取选中节点的node对象

    一.前言 树形组件是我们经常用到的组件,主要场景就是:公司后台管理的部门管理,做文章目录等。 二.常用的几种方法及说明 1.node-click:节点被点击时的回调 共三个参数,依次为:传递给  data  属性的数组中该节点所对应的对象、 节点对应的 Node 、节点组件本身。 2.c

    2024年02月16日
    浏览(40)
  • 【高阶数据结构】AVL树 {概念及实现;节点的定义;插入并调整平衡因子;旋转操作:左单旋,右单旋,左右双旋,右左双旋;AVL树的验证及性能分析}

    二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。因此,两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年发明了一种解决上述问题的方法: AVL树:又被称为高度平衡搜索二叉树,

    2024年02月10日
    浏览(42)
  • 当年知乎上那个被劝买比特币的学生后来怎么样了

    从2011年到2024年,比特币从3美元一度蹿升至最高点时的7.4万美元,如果那个大三学生将6000元全部买了比特币,此时早已是千万身家。 区块链欧意平台:by3.top 区块链bi安平台:by4.top 错过比特币的知乎女孩称很后悔当初没有听长铗的建议买比特币。在接受专访时,长铗也表示

    2024年04月14日
    浏览(30)
  • Elasticsearch3节点集群配置账号密码安全验证

    Elasticsearch3节点集群配置账号密码安全验证 ES配置文件 生成CA证书 拷贝证书文件到es节点目录 拷贝证书到es节点并授权 拷贝es配置文件到es节点 三个节点启动ES 登录任一节点设置密码 配置kibana

    2024年02月14日
    浏览(42)
  • 记录--实现金币飞入钱包的动画

    金币从初始位置散开后逐个飞向指定位置,这是游戏中很常用的一个动画,效果如下: 这个效果中,分成两个阶段: 一定数量的金币从一个起点散开 这些金币逐一飞向终点 计算金币的初始散开位置 生成圆周上的等分点 金币散开的位置看似随机,但实际上是围绕起点形成一

    2024年02月05日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包