对于离线交易不做过多解释~,说白了就是拿上一笔未发出交易记录进行私钥的签名然后广播到链上。

主要是对区块链离线交易进行utxo上链。

代码参考: https://gitee.com/DHing/signature-transaction

UnspentUtxo交易查询参考:https://blog.csdn.net/u011663149/article/details/91855077

离线签名(非隔离见证地址):

import java.util.ArrayList;
import java.util.List;import org.apache.commons.codec.binary.Hex;
import org.apache.commons.configuration2.Configuration;
import org.bitcoinj.core.Address;
import org.bitcoinj.core.Coin;
import org.bitcoinj.core.Context;
import org.bitcoinj.core.DumpedPrivateKey;
import org.bitcoinj.core.ECKey;
import org.bitcoinj.core.NetworkParameters;
import org.bitcoinj.core.Sha256Hash;
import org.bitcoinj.core.Transaction;
import org.bitcoinj.core.TransactionOutPoint;
import org.bitcoinj.core.UTXO;
import org.bitcoinj.core.Utils;
import org.bitcoinj.params.MainNetParams;
import org.bitcoinj.params.TestNet3Params;
import org.bitcoinj.script.Script;
import org.omg.CORBA.UNKNOWN;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import com.alibaba.fastjson.JSON;
import com.bscoin.coldwallet.cointype.common.ConfigUtil;
import com.bscoin.coldwallet.cointype.common.UnSpentUtxo;import org.bitcoinj.core.TransactionConfidence;/**  * @ClassName: RawTransaction  * @author DHing  *
*/
public class RawTransaction {private static Logger LOG = LoggerFactory.getLogger(RawTransaction.class);static NetworkParameters params;static {try {Configuration config = ConfigUtil.getInstance();params = config.getBoolean("bitcoin.testnet") ? TestNet3Params.get() : MainNetParams.get();LOG.info("=== [BTC] bitcoin  client networkID:{} ===", params.getId());} catch (Exception e) {LOG.info("=== [BTC] com.bscoin.coldwallet.cointype.btc.rawtransaction:{} ===", e.getMessage(), e);}}/**  * @Title: signTransaction* @param @param privKey 私钥* @param @param recevieAddr 收款地址* @param @param formAddr 发送地址* @param @param amount 金额* @param @param fee 手续费(自定义 或者 默认)* @param @param unUtxos 未交易的utxo* @param @return    参数  * @return char[]    返回类型  * @throws  */  public static String signTransaction(String privKey, String recevieAddr, String formAddr, long amount, long fee, List<UnSpentUtxo> unUtxos) {if(!unUtxos.isEmpty() && null != unUtxos){List<UTXO> utxos = new ArrayList<UTXO>();// String to a private keyDumpedPrivateKey dumpedPrivateKey = DumpedPrivateKey.fromBase58(params, privKey);ECKey key = dumpedPrivateKey.getKey();// 接收地址Address receiveAddress = Address.fromBase58(params, recevieAddr);// 构建交易Transaction tx = new Transaction(params);tx.addOutput(Coin.valueOf(amount), receiveAddress); // 转出// 如果需要找零 消费列表总金额 - 已经转账的金额 - 手续费long value = unUtxos.stream().mapToLong(UnSpentUtxo::getValue).sum();Address toAddress = Address.fromBase58(params, formAddr);long leave  = value - amount - fee;if(leave > 0){tx.addOutput(Coin.valueOf(leave), toAddress);}// utxos is an array of inputs from my walletfor (UnSpentUtxo unUtxo : unUtxos) {utxos.add(new UTXO(Sha256Hash.wrap(unUtxo.getHash()),unUtxo.getTxN(),Coin.valueOf(unUtxo.getValue()), unUtxo.getHeight(), false,new Script(Utils.HEX.decode(unUtxo.getScript())),unUtxo.getAddress()));}for (UTXO utxo : utxos) {TransactionOutPoint outPoint = new TransactionOutPoint(params, utxo.getIndex(), utxo.getHash());// YOU HAVE TO CHANGE THIStx.addSignedInput(outPoint, utxo.getScript(), key, Transaction.SigHash.ALL, true);}Context context = new Context(params);tx.getConfidence().setSource(TransactionConfidence.Source.NETWORK);tx.setPurpose(Transaction.Purpose.USER_PAYMENT);LOG.info("=== [BTC] sign success,hash is :{} ===",tx.getHashAsString());return new String(Hex.encodeHex(tx.bitcoinSerialize()));}return null;}public static void main(String[] args) {List<UnSpentUtxo> us = new ArrayList<UnSpentUtxo>();UnSpentUtxo u = new UnSpentUtxo();u.setAddress("mifiHFYFPk5cri4oneXVsRZJZKovvdDcjo");u.setHash("2bc6ac92468c2b4f1fcd2349822dc4663dfc0705b30131087a20ed8d17de8274");u.setHeight(  1413239);u.setScript("76a914a1806613a51a81966779e2fa1537013cf4cd2b1788ac");u.setTxN(1);u.setValue(100000);UnSpentUtxo u1 = new UnSpentUtxo();u1.setAddress("mvEtuEqYPMrLaKjJ5nTZ57vQAoYUtVmMaQ");u1.setHash("1893b6ff8ef2bd6f5d652937ffbaed5bb669c5d9ab450066253d6692f2d4d972");u1.setHeight(1413334);u1.setScript("76a914a1806613a51a81966779e2fa1537013cf4cd2b1788ac");u1.setTxN(1);u1.setValue(400000);us.add(u);us.add(u1);System.out.println(JSON.toJSONString(us));String c = signTransaction("cNRE3D1pbPPvGs9wpZd3X9NuLsuUQPzPa7ktQyF1nhqBabraocU9", "mifiHFYFPk5cri4oneXVsRZJZKovvdDcjo", "mvEtuEqYPMrLaKjJ5nTZ57vQAoYUtVmMaQ", 400000, 10000, us);System.out.println(c);}
}
package com.bscoin.coldwallet.cointype.common;import java.io.Serializable;public class UnSpentUtxo implements Serializable {private static final long serialVersionUID = -7417428486644921613L;private String hash;//交易hashprivate long txN; //private long value;//金额private int height;//区块高度private String script;//hexprivate String address;//钱包地址public String getHash() {return hash;}public void setHash(String hash) {this.hash = hash;}public long getTxN() {return txN;}public void setTxN(long txN) {this.txN = txN;}public long getValue() {return value;}public void setValue(long value) {this.value = value;}public int getHeight() {return height;}public void setHeight(int height) {this.height = height;}public String getScript() {return script;}public void setScript(String script) {this.script = script;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}}

签名成功返回Hex,使用https://live.blockcypher.com/btc-testnet/decodetx/ 进行解码查看交易详情:

最后:

调用节点钱包api: sendrawtransaction(hex:object) 传入生成的Hex即可进行广播交易了。

区块链钱包—BTC Java版离线签名交易相关推荐

  1. 从零开始创建自己的区块链应用(JAVA版)

    本文阅读对象,主要是希望和即将从事区块链开发的项目架构师,开发工程师,项目设计或产品设计师.要求阅读者具备一定的"区块链"基础知识.概念和以及相关的技术知识. 如果你只需要对区块链 ...

  2. (三)区块链钱包之加密算法简介

    (一)区块链钱包之生成助记词 (二)区块链钱包之创建钱包地址 (三)区块链钱包之加密算法简介 (四)区块链钱包之创建比特离线交易(BTC交易) (五)区块链钱包之创建以太坊交易(ETH交易) 钱包作为 ...

  3. (一)区块链钱包之生成助记词

    (一)区块链钱包之生成助记词 (二)区块链钱包之创建钱包地址 (三)区块链钱包之加密算法简介 (四)区块链钱包之创建比特离线交易(BTC交易) (五)区块链钱包之创建以太坊交易(ETH交易) 助记词 ...

  4. 基于Java的Android区块链钱包开发(ETH篇)

    基于Java的Android区块链钱包开发-ETH篇 引言 使用的库 具体代码如下 生成公私钥.地址 查余额.签名转账 引言 首先要生成12个助记词,区块链开发之生成12个助记词 使用的库 imple ...

  5. java语言分析区块链钱包生成的原理

    java语言分析区块链钱包生成的原理: 一.区块链钱包实现的技术原理用大概就是: 钱包助记词生成了种子,种子发芽结果,果实就是私钥,私钥推导出了公钥,公钥数据的节选部分成了钱包地址.同时钱包提供了Ke ...

  6. 区块链钱包开发(Android篇)

    区块链钱包开发(Android篇) 2018年10月27日 23:07:08 a526247082 阅读数 6309 简介 本文主要内容为区块链钱包移动端(Android)开发,介绍比特币钱包和以太坊 ...

  7. 区块链钱包有哪些?kinmall:它能成为区块链行业的支付宝...

    说到"钱包",首先最容易想到的是传统的实体钱包,那么,区块链钱包又是什么呢?顾名思义,它也是装"钱"的,只不过它装的是"数字货币",像是比特 ...

  8. 区块链开发指南_区块链钱包开发

    开发钱包之前,我们需要有以下的预备知识. 第一,什么是钱包,以及相关的分类. 本文站在开发者的角度,给读者讲解下怎么样和钱包进行交互,以及如何开发一个钱包. 我们怎么样理解钱包呢?简单讲它是连接区块链 ...

  9. 区块链技术架构 java_《区块链底层设计Java实战》之第二章区块链架构

    第2 章   区块链架构 会当凌绝顶  一览众山小 正如开篇所言:会当凌绝顶,一览众山小.进入区块链底层开发前,我们需要 了解区块链底层的通用架构是如何设计的,从上而下地审视区块链底层的结构,做 到了 ...

最新文章

  1. boost::math::hypot用法的测试程序
  2. 前端学习(1424):ajax低版本兼容问题
  3. OpenCL、OpenGL 同时工作
  4. Sci下载工具 v2021
  5. idea高效找出全部未被使用的代码
  6. php mysql 字段自增_MySQL自增字段取值的详细介绍(附代码)
  7. python类的构造方法是_Python类中属性和构造方法的区别?
  8. LuoguP4233 射命丸文的笔记
  9. java程序利用HttpSessionListener实现统计在线人数(示例代码)
  10. Linux上mysql安装详细教程
  11. Android基础入门教程——7.6.3 基于TCP协议的Socket通信(2)
  12. 阿里巴巴集团学术委员会主席曾鸣纵论BAT人工智能战略:任何公司都必须AIl in AI
  13. 庆祝61-牛客模拟笔试七月场(使圆圈队形中相邻小朋友的身高差的最大值最小的解法)
  14. 尾行注释转行上注释 正则表达式
  15. macOS免费串口工具coolTerm/Minicom/Comtool/Volt+(伏特加)/友善串口调试助手/screen/picocom
  16. python 代码库之遍历ttf字库编码和字符(含demo)
  17. ATECLOUD智能云测试平台-测试测量/仪器程控/工业控制/上位机开发软件
  18. vue修改http请求头_vue-resouce设置请求头的三种方法
  19. guid linux 识别的分区表_教你硬盘分区表格式GUID和MBR怎么区分
  20. 数学建模模型2——多属性决策模型之加权算术平均算子【评价型】

热门文章

  1. 万能Ghost系统制作教程(转)
  2. Pycharm报错:FutureWarning: `distplot` is a deprecated function and will be removed in a future version
  3. 计算机为什么检测不到u盘启动项,电脑无法识别U盘启动BIOS里面找不到U盘启动项...
  4. 第七篇 indicators(3)第三方指标库Ta-lib
  5. 【论文笔记】CondConv: Conditionally Parameterized Convolutions for Efficient Inference
  6. macbook 打开以后没有声音,重启以后又好了的解决方法
  7. Ural 2045 Richness of words
  8. ServiceNow CSA管理员考试(ServiceNow Fundamentals (On Demand) Paris)
  9. 语雀 添加块级模式公式
  10. 关于STL中vector容器的一些总结