- _1 A; Y! F( g. [( I& I5 ^随着区块链技术的快速发展,各种加密货币和代币协议不断涌现。在以太坊的 ERC-20 代币协议成为行业标准之际,比特币社区也迎来了实验性质的 BRC-20 代币标准。BRC-20 标准采用简洁、安全的设计理念,实现了代币的部署、铸造和转移。BRC-20 基于比特币网络,通过在聪(Satoshis)上记录数据的方式实现代币的发行和管理。本文将介绍 BRC-20 的原理和应用以及优势和缺陷等方面的内容,以期为读者提供全面深入的了解。
长期以来,人们觉得比特币生态相对于以太坊来说不具有扩展性,因为除了转账交易以外,区块上几乎无法保存任何数据。BRC-20 近期爆火的原因在于它是基于比特币的代币标准,将 NFT 和其他代币引入了比特币生态。
重要的里程碑:
2020 年 1 月,比特币核心开发者 Pieter Wuille 发布了 BIP 341 和 BIP 342 比特币改进提案为比特币生态带来了可能性。
2022 年 6 月,Casey Rodarmor 对 BIP 342 中的Tapscript 做了技术延伸与扩展,并且提出新的比特币改进方案ordinal (序数)和 inscription(铭文),主要实现了比特币链上存储数据的功能。
2023 年 3 月,Domodata 进行 ERC-20 实验,通过Ordinal 协议和 inscriptions 功能,向比特币链上存储 json 数据,证明链下代币余额状态,变相的实现了向比特币生态发布代币的功能。
Domodata(BRC-20 作者)认为BRC-20 标准只是个有趣的实验,通过实验向我们展示了可以通过以创建链上铭文的方式证明链下代币余额的状态。他觉得这只是一次尝试,BRC-20 标准不应该被认为是唯一标准,同时鼓励比特币社区的人们共同努力修补和优化标准,并且BRC-20 的作者还认为在比特币上发行资产目前是存在着更好的方案的。
二、BRC-20 前置知识BRC-20 是基于 Ordinal 协议的代币标准。Ordinal 协议是一种针对比特币网络的扩展协议,它允许在比特币聪上铭刻数据。基于 Ordinal 协议,BRC-20 可以实现代币的发行、转移和交易。
BRC-20 的原理相对复杂,需要了解比特币网络上的一些概念,比如聪(Satoshis)、Ordinal、Inscription 和 Taproot 升级等。其中,聪是比特币网络的最小单位,Ordinal 理论对每个聪进行编号,Inscription 则是将数据刻在每个聪上,而 Taproot 升级相关的技术则是控制这些 Inscription 的机制。这些概念共同构成了 BRC-20 标准的运作逻辑。
(一)Satoshis(聪)Satoshis(聪)不是比特币,而是比特币的最小单位, 1 个比特币可以分割成 1 亿个聪。
(二)Ordinal(序数)序数理论是一种协议,用于将序列号分配给 satoshis(比特币的最小细分),并在交易花费时跟踪这些 satoshis。这些序列号都是很大的数字,比如这个 804766073970493 。每个聪,也就是一个比特币的 ¹⁄₁₀₀₀₀₀₀₀₀,都有一个序号。
。该项目包括几个部分一个是ordinal方案对比特币的改进建议,另外一个是用 rust 开发的 ord 工具,集成了索引、区块浏览器和命令行钱包的功能。后面我们会讲解到如何通过 ord 工具包刻录自己的铭文。
(三)inscription(铭文)Ordinal 协议通过为每个聪分配唯一编号并添加注释来实现扩展功能。这个过程被称为铭文(inscription),即为聪赋予衍生含义。注释即铭文内容写在了交易见证(witnesses)当中,使得聪可以刻写任何类型的内容。铭文内容大小限制在 3.9 M 以下会比较安全,因为铭文内容是包含在交易中的,所以内容越大,铭文交易需要支付的手续费就越高。
我们可以通过下载
#打印 ord 版本号
6 R. A1 Y- m* word --version
/ {0 g0 D! B6 k. T8 `8 Yord wallet create1 H$ C) `) H* u* M/ d4 Y3 Z
#获取钱包地址
5 J# ~: X. f* O( x# m( oord wallet receive) F6 i. I: c! P% ~0 H. [7 n
#查看待处理交易
" m; C0 H# u2 Y/ {& xord wallet transactions$ I4 y) a- w5 L
#创建 Inscriptions(铭文)6 @! G+ o! n- k5 }: W2 x5 d( O1 z
ord wallet inscribe --fee-rate FEE_RATE FILE* H3 t$ t7 D/ J2 n9 ^
#发送铭文
5 \* T4 V$ D, R$ U7 e& yord wallet send --fee-rate <FEE_RATE> <ADDRESS> <INSCRIPTION_ID>(四)BIP 341 和 BIP 342
BIP 341 和 BIP 342 是两个与比特币改进相关的提案。BIP 全称为 Bitcoin Improvement Proposal(比特币改进提案),用于描述比特币协议、客户端或环境的新特性、流程或规范。BIP 341 和 BIP 342 与 Taproot 升级有关,主要目的是提高比特币的隐私性和扩展性,而不是直接用于向区块链写入数据,但是 Taproot 升级可以使用比特币脚本和通过交易向区块链低成本写入数据,为 brc-20 标准进行了技术铺垫。
BIP 341 :Segregated Witness(隔离见证)输出,这个提案定义了新的输出类型,该输出类型实现了 Taproot 功能。这使得支持 Taproot 的交易可以与其他类型的交易在一个区块ZG存,同时维持向后兼容性。BIP 341 为新的输出类型提供了详细的描述和规范。
BIP 342 :Tapscript,这个提案描述了 Taproot 内部的脚本语言,称为 Tapscript。Tapscript 基于比特币的现有脚本语言,并对其进行了扩展和优化。BIP 342 定义了 Tapscript 的语法、运行环境和执行规则。这些改进使得在比特币网络中执行复杂的智能合约变得更加高效和隐私。
8 w1 z. W: m- O9 w# t
常规我们可以使用 OP_RETURN 操作码将一小段数据(最多 80 字节)附加到交易输出中,从而将数据永久写入比特币区块链中。如果需要存储更多的数据我们需要采用数据分割的方式,创建多个包含 OP_RETURN 的交易,向每个小块分别写入一段数据,这种方法会大大增加交易费用。
当 BIP 341 和 342 出现时,我们可以使用 P 2 WSH(Pay-to-Witness-Script-Hash),P 2 WSH 是 Segregated Witness(隔离见证)的一部分,他允许你创建一个比特币地址,该地址表示Witness-Script(见证脚本)的散列值,要花费这个地址的资金,必须提供满足该脚本的解锁条件的输入。具体流程如下:
1.创建一个包含您要存储的数据的见证脚本。您可以使用 OP_PUSHDATA 操作码将数据嵌入脚本中。
2.计算见证脚本的散列值(SHA-256 )。
3.使用散列值创建一个 P 2 WSH 地址。 4.创建一个比特币交易,将资金发送到 P 2 WSH 地址。
5.广播交易到比特币网络。
我们进行交易时,将解锁脚本从交易主体中分离,存储在 Witness(见证数据)中。通过该技术我们可以在任何比特区块的 Witness 部分存储高达 4 MB 的任意数据。这构成了任何比特币 Inscriptions(铭文)的上限为 4 MB。
三、BRC-20 的技术原理基于 ordinal 铭文的 BRC-20 标准,利用 Satoshis(聪)来存储和管理代币的各种信息,如代币名称、符号、总量等,将这些信息以 JSON 格式编码后写入 Satoshis(聪)中,组成了一个一个的铭文(inscriptions)。最后通过汇总所有铭文(inscriptions)的活动,便可以找到 BRC-20 通证的余额状态,从而实现了代币的部署、铸造和转账。
BRC-20 是一种基于比特币的实验性代币标准,核心思想是通过序数理论 (ordinal theory) 创建、铸造和转移 BRC-20 通证来实现在比特币区块链上进行资产管理。该实验主要包括以下几个方面:
部署(Deploy):创建 BRC-20 通证,需要设置通证参数,如代币符号、最大供应量和铸币限制等。部署过程仅用于初始化 BRC-20 ,不影响状态。
{4 l- d+ @: _, X$ ~! e
"p": "brc-20",7 C" r2 O1 Q! p) m/ F
"op": "deploy",
6 P, P" k' {$ ~( I; T# x% M "tick": "ordi",
8 [0 o- p& f2 z% q: u" S: l! u9 \0 q "max": "21000000",
/ i; r z; D3 J2 H "lim": "1000"
% [2 }$ L7 B% k5 g5 C}8 ^9 ~/ i# [* z" l" [$ ]
***************注释****************
. \* J% P5 n$ u5 U6 z( n& [3 D"p": "brc-20":指定协议为 BRC-20 ,有助于其他系统识别和处理 BRC-20 事件。+ q$ o+ \- N/ R- d% |1 _
"op": "deploy":指定操作类型为部署。
. @# d0 x1 }" B4 f& g; G" C) P! q# C"tick": "ordi":指定通证的 4 个字母标识符,这里用"ordi"作为演示文档中的示例,它的最大供应量已达到。
/ \& t6 x% N. V"max": "21000000":设置通证的最大供应量为 21, 000, 000 。
- P) _! I% q# \- \% p$ _"lim": "1000":设置每个序数的铸币限制为 1000 。
铸造(Mint):使用铸造功能铸造一定数量的 BRC-20 通证。铸造操作向铸币功能的初始所有者提供相应余额。若通证设有铸币限制,请确保不超过该限制。
{
9 T( o6 D" T+ T. s( N "p": "brc-20",% \3 y5 Y: K$ ^
"op": "mint",% m! K: ^) r# c5 f/ _2 Z: i
"tick": "ordi",9 L7 Y, U7 t) F$ S; r
"amt": "1000"
4 Q/ _* ^7 `/ i0 m}
6 C1 P( D9 _2 `***************注释****************
" Y$ v# B; i& K4 B, i- f"p": "brc-20":指定协议为 BRC-20 ,有助于其他系统识别和处理 BRC-20 事件。9 }7 g7 Z0 _8 g/ \7 m) X
"op": "mint":指定操作类型为铸造。
! s5 x2 h J+ Z"tick": "ordi":指定通证的 4 个字母标识符,这里用"ordi"作为示例。
! K# w4 N' e& @: ]2 F- r"amt": "1000":设置铸造的通证数量为 1000 。
转移(Transfer):通过转移功能转移 BRC-20 通证的一定数量。转移操作从发送者的余额中扣除通证,并将其添加至接收者的余额。转移功能仅在第一次转移时生效。
{
7 P( w( B! e0 B' ~4 r "p": "brc-20",
* i: c2 M a- E "op": "transfer",
8 O0 j) K+ u8 Q: U: A "tick": "ordi",- G6 s; E* [5 b
"amt": "100"
$ n5 F6 B$ Y: V2 F+ R" M}
& m! r8 q# Z/ R* n* z2 A. @***************注释****************
+ U+ b' r9 B0 R8 Y1 i- ^"p": "brc-20":指定协议为 BRC-20 ,有助于其他系统识别和处理 BRC-20 事件。
0 G9 |; h& u1 h5 M* K! C+ h"op": "transfer":指定操作类型为转移。
& B( Z2 M9 D1 {, f% K"tick": "ordi":指定通证的 4 个字母标识符,这里用"ordi"作为示例。( \3 G" y# T, E8 d8 ]) E+ G
"amt": "100":设置转移的通证数量为 100 。
状态追踪:我们创建链上铭文(inscriptions),向其中存储符合 BRC-20 标准的 json 数据的方式,可以证明链下代币部署、铸造,转移的状态。通过汇总链上所有铭文(inscriptions)的活动,可以找到 BRC-20 代币的余额状态。
2 c6 q! H5 H% `
9 D+ [! ? H3 j- a0 [& x& b5 X4 T2 J3 H# Z: z