Bitcoin交易及验证
UTXO 理解
未花费交易输出: Unspent Transxtion output
UTXO---用比特币拥有者的公钥锁定(加密)的一个数字UTXO== 比特币- 比特币系统里没有必有比特币,只有UTXO
- 比特币系统没有账户, 只有UTXO(公钥锁定)
- 比特币系统里没有账户余额,只有UTXO(账户月只是比特币钱包的概念)
- UTXO存在全节点的数据库里
- 转账将消耗掉属于自己的UTXO,同时生成新的UTXO,并用接收者的公钥锁定。
- 比特币系统没有账户概念。
交易的结构
- 交易的输出(UTXO)
- 锁定的比特币数量
- 锁定的脚本(用接收者的公钥哈希)
- 交易的输入(UTXO+解锁脚本)
- 解锁(自己的私钥)脚本(用发送者签名,接收者的公钥hash)
交易的确认
交易的确认必须放在区块链上才算完成
交易验证
基于栈的脚本语言
栈(
stack)- 操作数据的一种结构- 只能从一端操作数据,后进新出
LIFO(Last In, First Out) - 如同子弹匣,先压入的子弹最后打出
- 压栈(
PUSH),出栈(POP)
- 只能从一端操作数据,后进新出
验证交易- 基于栈的脚本语言
对栈的操作:
OP_DUP---逻辑运算符:
OP_EQUALVERIFY加解密运算符:
OP_HASH160OP_CHECKSIG
算数运算符:
OP_ADD--- 加0P_SUB--- 减OP_MUL--- 乘OP_DIV--- 除

逆波兰表示法
- 简易运算规则:
- 所有造作符号位于操作数的后面
- 遇到操作数(数字),则压栈
(PUSH) - Y遇到二元运算符(
+,-, x ,/)- 先将2个操作数出栈
pop - 然后对运算数进行计算
- 最后将计算结构压栈
- 先将2个操作数出栈
- 传统表达式(中缀表示法):
(1+2)*3 == 9 - 逆波兰表示法(后缀表示法):
1 2 + 3 * 9 ==
使用逆波兰表示法验证交易
锁定脚本
OP_DUP OP_HASH160<发送者公钥哈希> OP_EQUALVERIFY OP_CHECKSIG
解锁脚本
- <发送者的签名><发送者公钥>
交易验证:
签名公钥DUPHASH公钥哈希==验证签名运行解锁脚本+锁定脚本=> True
过程如下(逆波兰表示法):
a.
发送者签名与发送者公钥进行压栈(保护在解锁脚本正)b.
DUP--将公钥copy到栈顶c.
HASH运算符,只需要一个数,将公钥POP出去进行hash算法,生成一个公钥hashd. 将新生成的公钥哈希 压栈
e. 将锁定脚本(UTXO)中的公钥哈希压栈;
f.
OP_EQUALVERIFY---遇到==操作符,将栈中两个公钥哈希比较,为True的话,栈中的两个哈希公钥会废除掉,继续进行压栈操作g. 验证签名(
OP_CHECKSI)--POP出栈中的发送者签名与发送者公钥,使用公钥验证签名,如果通过,则UTXO可以使用

Bitcoin交易及验证的更多相关文章
- bitcoin 源码解析 - 交易 Transaction(三) - Script
bitcoin 源码解析 - 交易 Transaction(三) - Script 之前的章节已经比较粗略的解释了在Transaction体系当中的整体运作原理.接下来的章节会对这个体系进行分解,比较 ...
- bitcoin 源码解析 - 交易 Transaction(二) - 原理篇
这篇文章我断断续续写了呃···· 应该快三个星期了? 所以前后的风格可能差别相当大.真是十分的怠惰啊··· 最近实在是不够努力.用python重写bitcoin的项目也卡在网络编程部分(这方面真是我的 ...
- bitcoin源码解析 - 交易 Transcation (一)
比特币中的交易可谓是比特币的最核心部分.比特币由交易产生,而区块就是用来存储交易的.所以,交易是比特币存在的载体,同时也是比特币中最复杂的部分.交易的运作层层相扣,各个部分缺一不可,十分严密,由此体现 ...
- bitcoin 源码解析 - 交易 Transaction
bitcoin 源码解析 - 交易 Transaction(三) - Script 之前的章节已经比较粗略的解释了在Transaction体系当中的整体运作原理.接下来的章节会对这个体系进行分解,比较 ...
- 比特币交易(Transaction)的输入与输出
比特币通过“挖矿”机制保证了不能任意造币.通过分布式网络和HashCash机制解决双重支付问题.事实上比特币系统中不存在独立的电子货币,而只存在交易单(账单),货币值是依附于交易单存在的,所以比特币中 ...
- 比特币区块结构Merkle树及简单支付验证分析
在比特币网络中,不是每个节点都有能力储存完整的区块链数据,受限于存储空间的的限制,很多节点是以SPV(Simplified Payment Verification简单支付验证)钱包接入比特币网络,通 ...
- 金融量化分析【day112】:初识量化交易
一.摘要 为什么需要量化交易? 量化交易是做什么? 量化交易的价值何在? 做量化交易需要什么? 聚宽是什么? 零基础如何快速入门量化交易? 自测与自学 二.量化交易比传统交易强多少? 它能让你的交易效 ...
- Fabric交易流程
(内容可能有些乱,请见谅,日后会对格式进行整理!) #### 在1.0及以后的版本中,客户端应用会先向Fabric CA申请用户所需要的Fabric中的准入证书,用于签名提案以及交易,然后由客户端(A ...
- Facebook libra开发者文档- 3 -Life of a Transaction交易生命周期
Life of a Transaction交易的生命周期 https://developers.libra.org/docs/life-of-a-transaction 为了更深入地了解Libra交易 ...
随机推荐
- .Net上传图片压缩质量,不改变尺寸
图片上传有很多情况需要考虑,例如:生成缩略图.压缩尺寸.压缩质量.压缩尺寸质量.添加水印等等常见情况.最近遇到图片质量压缩不改变大小的问题,参考:听浪 #region 图片压缩 /// <sum ...
- python中的 小数据池 is 和 ==
1. 小数据池 一种数据缓存机制,也被称为驻留机制 小数据池针对的是:整数 , 字符 , 布尔值 .其他的数据类型不存在驻留机制 在python中对 -5 到256之间的整数会被驻留在内存中, 将一定 ...
- Http协议中关于Content-Length的解读【出现坑爹的视频中断】
最近公司的视频设备在下载视频的时候,出现了很诡异的现象,在新旧服务器一样的tpp包,下载下来后,新服务器无法解析,旧服务器没问题.且tpp包并没有改动. 后面找了挺久,终于发现了视频下载的时候是断点续 ...
- eclipse的debug模式经常自动跳到TheadPoolExecutor的断点
1.问题:eclipse的debug模式经常自动跳到TheadPoolExecutor的断点,实在烦人 解决方法是: 在eclipse中选择Window->Preference->Java ...
- zTree第四章,异步加载,后端
后端 ------------------------------------------------------------------------------------------------- ...
- MySQL之FOUND_ROWS()的用法
SELECT FOUND_ROWS() 输出8(输出该表共有多少列)
- MySQL之LIMIT用法
http://blog.163.com/niuxiangshan@126/blog/static/17059659520101081058299/ 看的人家的 mysql支持limitselect * ...
- jdk命令行工具(一)
1.概述 熟悉java开发的人应该都知道在jdk的bin目录下有许多的工具,这些工具主要用于监视虚拟机和故障处理.这些故障处理工具被Sun公司称作为“礼物”附赠给JDK的使用者,并在软件的使用说明中把 ...
- 使用 Hexo + github 搭建个人博客
来自:http://www.cnblogs.com/fengzheng/p/8031518.html Hexo 是什么 Hexo 是一个快速.简洁且高效的博客框架.Hexo 使用 Markdown(或 ...
- sele nium 模块
python3 web测试模块selenium 阅读目录 1.selenium安装配置 2.Selenium的基本使用 (1)声明浏览器对象 (2)定位元素 (3)元素对象(element) (4 ...