使用web3j进行交易转账

区块链技术Butterfly2018-02-06 19:35:55  阅读 -评论 3  阅读原文

目 录

1 Web3j概述

2 区块链基础

2.1 交易

3 实战经验

3.1 创建项目

3.2 导入依赖关系

3.3 连接以太坊客户端

3.4 使用admin连接以太坊客户端

3.5 解锁账号

3.6 获取交易手续费

3.7 创建交易事务

3.8 获取gas和balance

3.9 发送交易

3.10 验证交易

4 总结

1 Web3j概述

用于与Ethereum客户端集成的轻量级Java库。

2 区块链基础

对于编程者来说,区块链不是一个很难理解的概念,因为最难懂的部分(包括挖矿,哈希,椭圆加密,P2P网络)都只是提供了一系列的特性和约束,一旦你知道了这些特性和约束,就不必去理解这些特性或是约束背后的实现原理。

2.1 交易

区块链是全局共享,交易数据库。这就意味着任何人只要参与到这个网络中就可以访问到这个数据库。如果要修改数据库中的数据,就需要创建一个被其他所有在这个网络里的人所认可的交易。交易说明对数据的修改要么没有任何进行,要么就全部完成,不会出现部分完成,部分未完成的情况。而且一旦交易完成,被记录在数据库中,谁也无法修改这个交易。

举个例子,想象在一个电子货币里,用表列举出所有账号余额,当进行一个账号和另外一个账号进行交易时,交易数据库要确保交易金额要从交易发送方减去,并且在交易接收方增加同样的交易金额。如果交易过程中出现了任何原因导致交易失败,交易发送方增加金额的行为失败,那接收方的金额也不应该发生变化。

而且发送方都会对发起的交易进行签名加密。这直接地保证了数据库只能被指定的修改所修改。在电子货币的例子中,简单的检查能够确保只有持有这个账号的秘钥者才能对金额进行转移。

3 实战经验

3.1 创建项目

这里创建的是spring boot项目,因为spring boot方便管理,当然你也可以创建普通的maven项目。

3.2 导入依赖关系

主要有几个依赖:

1. 加密解密

2. 快速的JSON序列化和反序列化

3. http的网络连接

4. web3j的依赖

5. spring boot的依赖

3.3 连接以太坊客户端

这样是使用web3j最原始的连接方法,可以打印版本号和以太坊的信息,如果要创建交易,可以使用Admin来进行连接。

3.4 使用admin连接以太坊客户端

Admin admin =Admin.build(new HttpService());

3.5 解锁账号

//解锁账号

PersonalUnlockAccount personalUnlockAccount = admin.personalUnlockAccount(fromAccountId, password,ACCOUNT_UNLOCK_DURATION).

sendAsync().get(5, TimeUnit.MINUTES);

发送交易之前必须先解锁账号,否则可能会发生账号被锁定的情况而无法发生交易,解锁需要输入自己的密码,并且设置时间。

3.6 获取交易手续费

当一个事务发生在Ethereum时,必须向执行事务的客户端支付事务成本,将此事务的输出提交给Ethereum区块链。gas price 和gasLimit影响交易的速度这些参数一起决定了您愿意花费在交易成本上的最大数量的乙醚。即可以花费不超过天然气价格*天然气限制。天然气价格也会影响交易发生的速度,这取决于其他交易对于矿工而言是否有利可图的天然气价格。您可能需要调整这些参数以确保交易及时进行。

交易的gas limit 一定要等于或者大于交易使用的intrinsic gas, intrinsic gas包括:

* 1. 执行交易预订费用为21,000gas.

* 2. 随交易发送的数据的gas费用(每字节数据或代码为0的费用为4gas,每个非零字节的数据或代码费用为68gas)。

* 3. 如果是合约创建交易,还需要额外的32,000gas 目前区块的gas limit是 4,712,357 gas,数据来自于ethstats.net.

* 这表示着大约224笔转账交易(gas limit为21000)可以被塞进一个区块(区块时间大约在15-20秒间波动)。

* 这个协议允许每个区块的矿工调整区块gas limit,任意加减1/2024(0.0976%)。

Nonce

为了防止交易的重播攻击,每笔交易必须有一个nonce随机数,针对每一个账户nonce都是从0开始,当nonce为0的交易处理完之后,才会处理nonce为1的交易,并依次加1的交易才会被处理。以下是nonce使用的几条规则:

  • 当nonce太小,交易会被直接拒绝;
  • 当nonce太大,交易会一直处于队列之中。

3.7 创建交易事务

为了纪念第一次交易,我们把hello eth 作为标记打入到ETH里面。ETH要求打印的标记必须是16进制,而且以0x开头,这里我们使用Numeric类的方法把我们的标记打入进去。

为了纪念第一次交易我们把hello eth 作为标记打入到ETH里面。ETH要求打印的标记必须是16进制,而且以0x开头,这里我们使用Numeric类的方法把我们的标记打入进去。

3.8 获取gas和balance

3.9 发送交易

这里采用的是异步发送交易的方式,tradeHash可以获取我们交易返回的Hash码,最后我们需要根据Hash码找到我们的数据。

3.10 验证交易

EthTransactionethTransaction=admin.ethGetTransactionByHash(tradeHash).send();

org.web3j.protocol.core.methods.response.Transaction transactionResult = ethTransaction.getResult();

System.out.println(transactionResult.getValue());

transactionResult里面是我们返回的数据,可以查看到blockHash,gas,nonce等信息,我们取出input,这是我们的输入参数,然后把16进制转码为10进制就可以看到我们的hello eth.

4 总结

通过web3j 交易接口的调用我们对eth的交易步骤和交易所需要的条件都已经有所了解,这个对于我们以后开发钱包和发送离线交易都有所帮助。


HPB芯链

立即加入我们的电报群:https://t.me/hpbfans

最新资讯将在群内同步实时更新!芯链团队正在等待你的到来!

声明:链世界登载此文仅出于分享区块链知识,并不意味着赞同其观点或证实其描述。文章内容仅供参考,不构成投资建议。投资者据此操作,风险自担。此文如侵犯到您的合法权益,请联系我们100@7234.cn

参与讨论 (3 人参与讨论)

相关推荐

区块链投资趋势报告:巨头入场布局行业趋于成熟

区块链投资趋势报告:巨头入场布局行业趋于成熟

来自:https://mp.weixin.qq.com/s?__biz=MzI4NzIxOTY1NA==&mid=2650632639&idx=1&sn=e6d1c29731d992a80410aaee82ec3ea6&chksm=f3d8db16c4af520097e4a64a71b1d4743ac326b9f027

重新发明货币

重新发明货币

一、货币的演化过程 先简单回顾一下人类货币的演化过程,大概有以下阶段: a. 1.0版本:自然货币(贝壳、牲口、金银……) 这个阶段,货币基于一般等价物的稀有性或者实用性,货币不可能出现人为操纵的超发。 b. 2.0版本:早期纸币、银票到本位纸币 当贸易量越来越大,实物货币太不方便了,而且大家发现其实并不在意货币本身有什么价值,在意的只是这么多的货币能不能交换到足够的物品,于是纸币这种信用货

从比特币交易看欧洲央行虚拟货币分类

从比特币交易看欧洲央行虚拟货币分类

  互联网对传统社会的颠覆从未停止,在其完成对信息流、商流、物流、资金流的初步改造之后,或将以虚拟货币的形式打破现有货币体系   4月18日,在中国极客张沈鹏创办的比特币交易平台(42BTC.com)上,比特币对人民币的平均交易价为576元。当天,该平台完成了100个比特币的交易量。仅仅过去一周,4月25日上午,比特币对人民币的平均交易价已达到906元。据42BTC网站统计:在过去的32个月

欧洲央行-比特币报告

3.1 比特币 3.1.1 基本特征          比特币可能是最成功的,也可能是最有争议的虚拟货币方案,由日本程序员中本聪(译者注:事实上,中本聪是不是日本人,甚至是不是单个人无从考证)在2009年设计并实现。该计划基于一个类似于BitTorrent的P2P网络。BitTorrent是互联网上著名的共享文件协议,应用在电影,游戏和音乐领域。比特币在全球层面上运作,可用于各类货币交易(虚

彻底玩转比特币地址和私匙

彻底玩转比特币地址和私匙

比特币地址和私匙是所有比特币初学者面对的一大难题,再加上那一串超长的字符串,让人更是摸不到头脑。 现在编者以问答的形式,带你一步步的揭开比特币地址和私匙的面纱。 还不知道什么是比特币地址和私匙的同学请点这里 问题一、比特币钱包由什么组成? 答 我们知道,比特币地址和私匙组成了比特币钱包,而私匙则决定了比特币地址上比特币的归属。 地址和私匙 问题二、如果只记得私匙我们还能还原比特币地址么? 答

用GO语言实现比特币算法

用GO语言实现比特币算法

本节的这个例子展示一点点高精度数学包math/big、一点点散列包hash、一点点加密包crypto,还有一点点测试包testing的知识。这里不介绍bitcoin协议和算法——尽管它们很有趣,而是试图指出,Go对多种操作系统的支持,是实现这种跨平台应用的理想语言。 位钱(bitcoin)是一种使用加密手段制作的分布式电子货币。它最初于1998年由Wei Dai提出,并由中本聪(Satoshi

详解比特币的找零机制

详解比特币的找零机制

比特币的找零机制一直让人有些迷惑,明明只向一个地址发送了比特币为什么 blockchain 上面的显示的有时是1个地址对多个地址,有时是多个地址对1个地址,有时又显示多个地址对多个地址? 为什么比特币资深用户要提醒大家当比特币钱包交易100次以上时再次交易后要重新备份钱包,恢复以前的钱包备份有可能会遭遇损失? 是的,这一切都是因为比特币的找零(Change)机制。本文参考 Bitcoin的维

玩转比特币客户端之一:C盘转移和加速下载

玩转比特币客户端之一:C盘转移和加速下载

C盘空间不足?交易数据下载速度太慢?别着急,乐享比特币教你轻松玩转比特币官方客户端。 所有新人开始接触比特币时做的第一件事情大多数是安装比特币的官方客户端。 安全起见大家最好直接访问官方发布渠道sourceforge的地址进行下载:http://sourceforge.net/projects/bitcoin/files/Bitcoin/ 该网页列出了各版本的官方比特币客户端,目前

麦妖榜
更新日期 2019-01-17
排名用户贡献值
1等待的宿命23695
2BitettFan23632
3六叶树20309
4天下无双16192
5lizhen00214782
6区块大康14502
7让时间淡忘14188
8冷风大q11188
9momo11174
10linjm122710573
返回顶部 ↑