pycoin学习笔记(5) 本地对交易签名(p2pkh)

注:本篇所有实验均在比特币测试网络(testnet)下进行

这次实验对交易进行本地签名,即不利用第三方钱包的签名功能。

本次的场景是,将mh4xx1pgjqLmjVUJxfdj3qV8BJaYARLdh9上的0.2btc转到2N113Ujyc6Pj7kvnZMyZNpAtAfj9EzoHStQ上去。

开始撸码:

from pycoin.ecdsa import generator_secp256k1, public_pair_for_secret_exponent
from pycoin.encoding import wif_to_secret_exponent, public_pair_to_sec
from pycoin.tx.Tx import Tx
from pycoin.tx.pay_to import build_hash160_lookup
from pycoin.tx.tx_utils import create_tx


exponent = wif_to_secret_exponent("KyBuY4RgVcvGfyqhv3DmET5UpYT3rA74nR3uY7cCA1JLXbDiSgsS")

初始化mh4xx1pgjqLmjVUJxfdj3qV8BJaYARLdh9的私钥。(这是十分机密的东西࿰

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());
ECC椭圆曲线在比特币中被用于加密和签名交易。以下是计算出比特币公钥的过程: 1. 选择椭圆曲线和基点 比特币使用的是secp256k1椭圆曲线,其基点为G。这个基点是一个预设的点,固定在曲线上。基点的坐标是一个大整数,用十六进制表示为: ``` G = 04 79BE667E F9DCBBAC 55A06295 CE870B07 029BFCDB 2DCE28D9 59F2815B 16F81798 483ADA77 26A3C465 5DA4FBFC 0E1108A8 FD17B448 A6855419 9C47D08F FB10D4B8 ``` 2. 选择私钥 私钥是一个随机数,通常是由计算机生成。私钥通常由256位二进制数表示,可以用十六进制表示。比特币私钥的范围是1到约2^256-1。 3. 计算公钥 公钥是由私钥通过椭圆曲线算法计算出来的。计算公钥的过程是: - 将私钥表示为一个大整数d - 通过基点G和私钥d计算出公钥Q 计算公式为: ``` Q = d * G ``` 这个公式表示将基点G与一个标量d相乘,得出的结果就是公钥Q。在比特币中,公钥通常用压缩格式表示,即只保留x坐标和一个标记位,表示y坐标的符号。 4. 生成比特币地址 比特币地址是由公钥生成的。比特币地址通常以1或3开头,表示这是一个Pay-to-PubkeyHash(P2PKH)或Pay-to-ScriptHash(P2SH)地址。生成地址的过程是: - 对公钥进行哈希处理,生成一个哈希值 - 将哈希值进行Base58Check编码,得到比特币地址 注意:在比特币中,P2PKH地址是最常用的地址类型。P2SH地址通常用于多重签名和其他高级功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值