好书/好文 [学习笔记] OP_RETURN

aaron67 · 2019年01月01日 · 225 次阅读
本帖已被设为精华帖!

本文首发我的博客,搬运一份到这来


比特币交易的全球总帐本,是公开的,匿名的,不可篡改的

账本记录了每笔交易的具体内容,以及他们被写入账本的确定的时间点(时间戳)

如果能将现实世界的数据埋进交易,一同写到账本里,事情就变得有些微妙了,比特币系统的潜在应用将不只局限于支付,多了很多“可玩性”

一些背景

可以把一份文件的电子指纹(哈希)放到账本中,配合时间戳,建立某个确定时间点后的文件存在性证明,以此声明版权

to record a digital fingerprint of a file in such a way that anyone could establish proof-of-existence of that file on a specific date by reference to that transaction.

也可以直接把文件内容放到帐本中,比如合同和遗嘱,账本数据不可篡改,以此证明文件内容未经改动,是当时意愿的表达

Coinbase交易不需要输入,可以在腾出空间的解锁脚本中放入自定义的数据

中本聪(Satoshi Nakamoto)在创世区块中留言,表达对现实金融系统的不满

Imgur

有的人在帐本里放上了爱情宣言

Imgur

早些时候的人们脑洞大开,还尝试了各种其他粗暴的方法

P2PKH的锁定脚本里有20字节的公钥哈希值,有的人甚至直接将数据放到这20字节里

这些“伪支付”产生的UTXO,因为不存在一个真实的私钥与“伪公钥哈希”对应,所以它们永远无法被消费,会一直存在于UTXO集中,导致UTXO数据库的大小不断“膨胀”

利用比特币账本存储支付无关的数据,一直都充满争议

一方面这种使用模型充满前景,扩展了比特币系统的应用领域,但又因为没有一个统一的合适的方式,也带来了一些不好的影响

从Bitcoin Core 0.9.0版本开始,通过全新的操作码OP_RETURN最终实现了妥协

OP_RETURN

如果某个交易输出,其锁定脚本以OP_RETURN操作码开头

OP_RETURN [数据]

我们称这是一个数据记录输出(Data Recording Output),这笔交易也被称为OP_RETURN交易,或Null Data交易

对“[数据]”部分的长度限制,“不同版本的比特币”也不尽相同,目前,Bitcoin(BTC)是80字节,而Bitcoin Cash(BCH)和Bitcoin SV(BSV)是220字节

OP_RETURN输出,随交易一同被写到账本中,但不会被当成UTXO,不会带来UTXO集的膨胀,所以其金额通常为0

任何非零金额的OP_RETURN输出,都不可消费,所以OP_RETURN还可以用来销毁(燃烧)比特币

需要注意的是,一笔标准交易,规定最多只能有一个OP_RETURN输出

Imgur

交易335724b8b1a399589dfc470e474a415dc04e20d7c72e03903a2edb889ee47fde(我隐藏了输入和第一个输出)

Imgur

你可以用这个工具,看看十六进制的UTF-8编码e4bda0e5a5bdefbc8ce4b896e7958ce38082是什么 😋

通过OP_RETURN,数据可以被优雅的埋进账本中,下面是一些有意思的尝试

参考

共收到 0 条回复
aaron67 将本帖设为了精华贴 01月01日 01:49
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册