隔离验证交易解析

btc 隔离验证解析

txid:072a182ee0bc52560ef31ad6210da37ada8478dfc7a9e67f1ce63fb526eb783a

十六进制数据:

01000000000101385a84280cf6069176f9f1143ca1ca31375ac932fa0a90ad62286da2243396440400000000ffffffff0280626a940000000017a9142b959a850d3db911f1c229bae9e4f09807aea4f68730a80e5a00000000220020701a8d401c84fb13e6baf169d59684e17abd9fa216c8cc5b9fc63d622ff8c58d04004830450221008d6b10441ad3e84befb00a2ff474822b8bdc8de1841365e47f6954131765652d022061883891e385c610053fc25c8541b0bec2ed7e97c831606752d1b9d95c72c84f014730440220613cfb14b339d11d96cd4f786ec3da6e0503d793e0bc08a9ecc6753cfa57754f022066740904c86c78bb17dbb9ba74544a706f949386c517295c59b429eaaa7f10f701695221022b003d276bce58bef509bdcd9cf7e156f0eae18e1175815282e65e7da788bb5b21035c58f2f60ecf38c9c8b9d1316b662627ec672f5fd912b1a2cc28d0b9b00575fd2103c96d495bfdd5ba4145e3e046fee45e84a8a48ad05bd8dbb395c011a32cf9f88053ae00000000

解析:
version

01000000

market

00

flag

01

input_num

01

tx_id

385a84280cf6069176f9f1143ca1ca31375ac932fa0a90ad62286da224339644

index

04

script

00000000

sequence

ffffffff

output_num

02

value1

80626a9400000000

script_len

17

script

a9142b959a850d3db911f1c229bae9e4f09807aea4f687

value2

30a80e5a00000000

script_len

22

script

0020701a8d401c84fb13e6baf169d59684e17abd9fa216c8cc5b9fc63d622ff8c58d2

/以下是witness 中的内容//
script_num

04 (不是 01 ,则有可能是多签名)

签名信息

00

第一个签名字节数

48

签名信息

30450221008d6b10441ad3e84befb00a2ff474822b8bdc8de1841365e47f6954131765652d022061883891e385c610053fc25c8541b0bec2ed7e97c831606752d1b9d95c72c84f01

第二个签名字节数

47

签名信息

30440220613cfb14b339d11d96cd4f786ec3da6e0503d793e0bc08a9ecc6753cfa57754f022066740904c86c78bb17dbb9ba74544a706f949386c517295c59b429eaaa7f10f701

赎回脚本字节数

69

OP_2 即m-n 中的m = 2

52

第一个公钥字节数

21

pubkey1

022b003d276bce58bef509bdcd9cf7e156f0eae18e1175815282e65e7da788bb5b

第二个公钥字节数

21

pubkey2

035c58f2f60ecf38c9c8b9d1316b662627ec672f5fd912b1a2cc28d0b9b00575fd

第三个公钥字节数

21

pubkey3

03c96d495bfdd5ba4145e3e046fee45e84a8a48ad05bd8dbb395c011a32cf9f880

OP_3 即m-n 中的n = 3

53

OP_CHECKSIGVERIFY

ae

///

锁定时间

00000000

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
bitcoinj项目富含完整demo 此项目使用maven构建,不会使用maven的同学,查看项目pom.xml文件,并在http://mvnrepository.com/下载相应的依赖jar包. demo:bitcoinj签名交易 /** * @param unSpentBTCList 未花费utxo集合 * @param from 发送者地址 * @param to 接收者地址 * @param privateKey 私钥 * @param value 发送金额.单位:聪 * @param fee 旷工费.单位:聪 * @return 签名之后未广播的原生交易字符串 * @throws Exception */ public static String signBTCTransactionData(List unSpentBTCList, String from, String to, String privateKey, long value, long fee) throws Exception { NetworkParameters networkParameters = null; // networkParameters = MainNetParams.get(); //测试网络 networkParameters = TestNet3Params.get(); Transaction transaction = new Transaction(networkParameters); DumpedPrivateKey dumpedPrivateKey = DumpedPrivateKey.fromBase58(networkParameters, privateKey); ECKey ecKey = dumpedPrivateKey.getKey(); long totalMoney = 0; List utxos = new ArrayList(); //遍历未花费列表,组装合适的item for (UnSpentBTC us : unSpentBTCList) { if (totalMoney >= (value + fee)) break; UTXO utxo = new UTXO(Sha256Hash.wrap(us.getTxid()), us.getVout(), Coin.valueOf(us.getSatoshis()), us.getHeight(), false, new Script(Hex.decode(us.getScriptPubKey()))); utxos.add(utxo); totalMoney += us.getSatoshis(); } transaction.addOutput(Coin.valueOf(value), Address.fromBase58(networkParameters, to)); // transaction. //消费列表总金额 - 已经转账的金额 - 手续费 就等于需要返回给自己的金额了 long balance = totalMoney - value - fee; //输出-转给自己 if (balance > 0) { transaction.addOutput(Coin.valueOf(balance), Address.fromBase58(networkParameters, from)); } //输入未消费列表项 for (UTXO utxo : utxos) { TransactionOutPoint outPoint = new TransactionOutPoint(networkParameters, utxo.getIndex(), utxo.getHash());

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值