Output(交易输出)
介绍交易输出的数据结构及其作用。
什么是交易输出
比特币交易的输出(Transaction Output,简称“vout”)是指比特币交易中包含的付款目标及其金额。每个输出定义了接收方和他们将收到的比特币数量。
交易输出字段的结构
每个交易输出包含以下几个关键字段:
1. 数量(value)
这是一个8字节的整数,表示该输出的比特币数量,单位是聪(Satoshi)。1比特币等于100,000,000聪。
2. 锁定脚本(scriptPubKey)
锁定脚本是一个可变长度的字段,定义了如何解锁和使用这个输出。通常是接收方的公钥哈希(P2PKH)或其他复杂的脚本。
示例
以下是一个比特币交易输出的示例,使用JSON格式表示:
"vout": [
{
"value": 0.01500000,
"n": 0,
"scriptPubKey": {
"asm": "OP_DUP OP_HASH160 89abcdef... OP_EQUALVERIFY OP_CHECKSIG",
"hex": "76a91489abcdef...",
"reqSigs": 1,
"type": "pubkeyhash",
"addresses": [
"1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa"
]
}
}
]
在这个示例中:
- value 表示接收方将收到的比特币数量。
- scriptPubKey 包含了锁定脚本的详细信息。
- n 是输出的索引位置。
- reqSigs 表示解锁这个输出所需的最少签名数量。
- type 指定了锁定脚本的类型(如P2PKH)。
- addresses 是接收方的比特币地址。
交易输出的作用
1. 指定接收方
交易输出定义了比特币的接收方,确保比特币被正确转移到预定的目标地址。
2. 锁定和解锁机制
通过锁定脚本,交易输出 可以设置复杂的条件来控制比特币的使用。只有满足这些条件,才能解锁并使用这些比特币。
3. 多重签名支持
交易输出可以支持多重签名,通过reqSigs
字段指定解锁比特币所需的签名数量,提高了交易的安全性。
交易输出的类型
1. Pay-to-PubKeyHash (P2PKH)
最常见的输出类型,锁定脚本包含接收方的公钥哈希,解锁时需要提供对应的公钥和签名。
2. Pay-to-Script-Hash (P2SH)
输出被锁定到一个哈希值对应的脚本,解锁时需要提供能生成该哈希值的脚本和相应的输入。
3. 多重签名输出
要求多个签名来解锁比特币,通常用于需要多方共同签署的交易。
总结
交易输出是比特币交易中的关键组成部分,定义了比特币的接收方和数量。通过锁定脚本,交易输出确保比特币只能被合法的接收方使用。了解交易输出的结构和作用,有助于深入理解比特币交易的工作原理和安全机制。