Ⅰ 【ETH钱包开发04】web3j转账ERC-20 Token
在上一篇文章中讲解了ETH转账,这一篇讲一下ERC-20 Token转账。
【ETH钱包开发03】web3j转账ETH
1、直接用web3j的API
2、java/Android调用合约的 transfer 方法
不管用哪种方式来转账,你都需要先写一个solidity智能合约文件来创建ERC-20 Token,然后部署合约,最后才是通过客户端来调用。
注意:erc-20 token转账和eth转账的区别如下:
1、erc-20 token创建交易对象用的是这个方法 createTransaction
2、erc-20 token需要构建 Function ,它其实对应的就是erc-20 token合约中的那些方法。它的第一个参数就是ERC20中那几个方法的名称,第二个参数的话就是对应合约方法中的参数,第三个参数是和第二个参数对应的,按照我那样就行了。转账的话就是 transfer ,我们从合约的 transfer 可以看到第一个参数是收款地址,第二个参数是金额,所以 Function 这里对应起来就好。
这种方法不需要使用web3j封装的方法,而是直接调用solidity合约的方法。
步骤
1、web3j加载一个已经部署的合约
2、验证合约是否加载成功 isValid
3、如何加载合约成功,则调用合约的 transfer 方法
注意:
1、这里的 TokenERC20 是根据solidity智能合约生成的对应的Java类,用于java/Android和智能合约交互的,如果你对这里不太清楚,不妨看看我之前的一篇文章。
以太坊Web3j命令行生成Java版本的智能合约
2、如果加载合约失败,可能的一个原因是合约对应的Java类中的 BINARY 的值不对,这个值是你部署合约成功之后的bytecode,你最好检查对比一下。
我发送一笔交易,可以通过这个地址查询
https://rinkeby.etherscan.io/tx/
Ⅱ 为什么大多数区块链项目不使用java开发
区块链项目对效率的要求比较高,所以大多数核心源码的开发都是使用c/c++。但是如果是做都区块链项目,除非要对源代码进行大量的调整,否则也不见得就不选择使用java。一般的dapp应用,使用java开发应该也是不错的选择。比如以太坊区块链的话,针对java的有web3j的类库,十分方便;比特币的话有bitcoinj类库,也很好用。还是要看还是什么级别的应用,要做什么,以及团队的情况吧。
分享两个java区块链教程:
java比特币详解
java以太坊开发
Ⅲ 【ETH钱包开发02】导入钱包
本文主要讲解通过助记词、keystore、私钥 3种方式来导入钱包。导入钱包就是说根据输入的这3者中的一个去重新生成一个新的钱包。导入钱包的过程和创建的过程其实是差不多的。
根据助记词导入钱包不需要原始密码,密码可以重新设置。根据用户输入的助记词,先验证助记词的合规性(格式、个数等),验证正确后,配合用户输入的密码重新生成一个新的钱包。
验证助记词的合规性(格式、个数等)
助记词导入钱包
通过私钥导入钱包其实和创建钱包的过程基本一致。因为私钥在导出的时候转换成了16进制,所以在导入私钥的时候,要把16进制转换为byte数组。
keystore就是钱包文件,实际上就是钱包信息的json字符串。导入keystore是需要输入密码的,这个密码是你最后导出keystore时的密码。将keystore字符串变成walletFile实例再通过 Wallet.decrypt(password, walletFile); 解密,成功则可以导入,否则不能导入。
这是Web3j的API,程序走到这里经常OOM!
具体原因的话,我就不多说了,细节大家可以看这里
https://www.jianshu.com/p/41d4a38754a3
解决办法
根据源码修改 decrypt 方法,这里我用一个已经修改好的第三方库
修改后的解密方法
导入Kestore
1、导入助记词和私钥是不需要以前的密码的,而是重新输入新的密码;导入Keystore则需要以前的密码,如果密码不正确,会提示地址和私钥不匹配。
2、关于备份助记词
用过imtoken的同学可以看到imtoken是可以导出(备份)助记词的。这个一开始我也很困惑,后来了解到其实它实在创建钱包的时候,在app本地保存了助记词,导出只是讲数据读取出来而已。还有一点,imtoken一旦备份了助记词之后,之后就没有备份那个功能了,也就是说助记词在本地存储中删除了;而且导入钱包的时候也是没有备份助记词这个功能的。
Ⅳ 【ETH钱包开发03】web3j转账ETH
在之前的文章中,讲解了创建、导出、导入钱包。
【ETH钱包开发01】创建、导出钱包
【ETH钱包开发02】导入钱包
本文主要讲解以太坊转账相关的一些知识。交易分为ETH转账和ERC-20 Token转账,本篇先讲一下ETH转账。
1、解锁账户发起交易。钱包keyStore文件保存在geth节点上,用户发起交易需要解锁账户,适用于中心化的交易所。
2、钱包文件离线签名发起交易。钱包keyStore文件保存在本地,用户使用密码+keystore的方式做离线交易签名来发起交易,适用于dapp,比如钱包。
本文主要讲一下第二种方式,也就是钱包离线签名转账的方式。
交易流程
1、通过keystore加载转账所需的凭证Credentials
2、创建一笔交易RawTransaction
3、使用Credentials对象对交易签名
4、发起交易
注意以下几点:
1、Credentials
这里,我是通过获取私钥的方式来加载 Credentials
还有另外一种方式,通过密码+钱包文件keystore方式来加载 Credentials
2、nonce
nonce是指发起交易的账户下的交易笔数,每一个账户nonce都是从0开始,当nonce为0的交易处理完之后,才会处理nonce为1的交易,并依次加1的交易才会被处理。
可以通过 eth_gettransactioncount 获取nonce
3、gasPrice和gasLimit
交易手续费由gasPrice 和gasLimit来决定,实际花费的交易手续费是 gasUsed * gasPrice 。所有这两个值你可以自定义,也可以使用系统参数获取当前两个值
关于 gas ,你可以参考我之前的一篇文章。
以太坊(ETH)GAS详解
gasPrice和gasLimit影响的是转账的速度,如果gas过低,矿工会最后才打包你的交易。在app中,通常给定一个默认值,并且允许用户自己选择手续费。
如果不需要自定义的话,还有一种方式来获取。获取以太坊网络最新一笔交易的 gasPrice ,转账的话, gasLimit 一般设置为21000就可以了。
Web3j还提供另外一种简单的方式来转账以太币,这种方式的好处是不需要管理nonce,不需要设置gasPrice和gasLimit,会自动获取最新一笔交易的gasPrice,gasLimit 为21000(转账一般设置成这个值就够用了)。
这个问题,我想是很多朋友所关心的吧。但是到目前为止,我还没有看到有讲解这方面的博客。
之前问过一些朋友,他们说可以通过区块号、区块哈希来判断,也可以通过Receipt日志来判断。但是经过我的一番尝试,只有 BlockHash 是可行的,在web3j中根据 blocknumber 和 transactionReceipt 都会报空指针异常。
原因大致是这样的:在发起一笔交易之后,会返回 txHash ,然后我们可以根据这个 txHash 去查询这笔交易相关的信息。但是刚发起交易的时候,由于手续费问题或者以太网络拥堵问题,会导致你的这笔交易还没有被矿工打包进区块,因此一开始是查不到的,通常需要几十秒甚至更长的时间才能获取到结果。我目前的解决方案是轮询的去刷 BlockHash ,一开始的时候 BlockHash 的值为0x00000000000,等到打包成功的时候就不再是0了。
这里我使用的是rxjava的方式去轮询刷的,5s刷新一次。
正常情况下,几十秒内就可以获取到区块信息了。
区块确认数=当前区块高度-交易被打包时的区块高度。
Ⅳ 使用Web3J与第三方合约交互——批量转账
之前使用NodeJs与智能合约交互,都是访问的自己部署的合约。最近要对线上第三方合约进行转账操作,人数比较多,一笔笔操作起来手指都点断了还容易出错。既然代币Token都遵守ERC20协议,肯定有统一的Transfer(转账)方法供客户端调用,那么编写程序实现自动转账应该可以实现,去查了相关资料发现web3j是不错的选择。
轻量级客户端与以太坊交互的Java库。
既然是调用第三方合约那么肯定需要知道合约地址,合约地址定义了到哪里去访问合约;
ABI(Application Binary Interface): 应用程序二进制接口,定义了智能合约提供的方法功能
若是无法获取到ABI接口,也可以使用solc编译生产bin和abi文件。
(生产代理类时可以指定包路径和类名)
这样一来,便可以使用程序完成批量转账操作。
后来研究发现,使用NodeJs直接调用Web3也可以实现对应功能,不过还是对Java更熟悉一些,就采用了Java的方式。
Ⅵ 怎么在区块链上抢众筹
php网站怎么接入区块链众筹
php网站怎么接入区块链众筹,基于区块链的众筹平台及方法与流程
风雪轩
转载
关注
0点赞·332人阅读
本发明属于众筹领域,特别是涉及一种基于区块链的众筹平台及方法。
背景技术:
目前市面上出现了水滴筹、轻松筹和无忧筹等一系列的大病筹款系统,患者可以在这些大病筹款系统上进行筹款。这些大病筹款系统号称不收任何手续费,但是很多人无法相信这点,毕竟任何企业都是要盈利的,没有哪家敢公布汇款记录,存在着暗箱操作的可能,在公信力方面有很大欠缺。
技术实现要素:
本发明的目的在于克服现有技术的不足,提供一种基于区块链的众筹平台及方法,利用区块链记录每一笔筹款的交易记录,任何人均可查询交易记录,解决捐款人的顾虑。
本发明的目的是通过以下技术方案来实现的:基于区块链的众筹平台,包括:
患者模块,用于患者方在众筹平台上发布众筹信息;
审核模块,用于对所述患者方发布的众筹信息进行审核;
推广模块,用于将审核通过的众筹信息进行发布和推广;
捐款模块,用于捐款人采用数字货币向患者方的众筹账户进行捐款;
区块链模块,用于记录众筹过程中的数据信息;
处理模块,用于在区块链模块中为众筹信息通过审核的患者方建立一个众筹账户,并在筹款截止后根据当前币种汇率将所述众筹账户中的资金兑换成现金流汇到患者方的银行账户;以及用于将患者方的众筹信息、捐款人的捐款信息和向患者方的银行账户汇款的汇款信息记录在区块链模块中;
查询模块,用于查询人查看众筹信息、捐款信息和汇款信息。
优选的,所述基于区块链的众筹平台还包括:
举报模块,用于举报人对患者方发布的众筹信息进行举报;
核实模块,用于对举报人的举报信息进行核实。
优选的,所述患者模块包括:
注册子模块,用于患者方注册平台账号;
登录子模块,用于患者方登录所述平台账号;
信息发布子模块,用于患者方在登录所述平台账号后发布众筹信息。
基于区块链的众筹方法,包括:
患者方在众筹平台上发布众筹信息;
众筹平台对所述患者方发布的众筹信息进行审核,若审核通过则在区块链模块上为所述患者方建立一个众筹账户,并将所述患者方的众筹信息记录在区块链模块上;
将审核通过的众筹信息进行发布和推广;
捐款人采用数字货币向所述患者方的众筹账户进行捐款,众筹平台将捐款人的捐款信息记录在区块链模块上;
在患者方筹款截止后,众筹平台根据当前的币种汇率将所述患者方的众筹账户中的资金兑换成现金流,并将所述现金流汇到患者方的银行账户中。
优选的,所述基于区块链的众筹方法还包括:
查询人员通过众筹平台查看患者方的众筹信息、捐款人的捐款信息以及众筹平台向患者方的银行账户进行汇款的汇款信息。
优选的,所述基于区块链的众筹方法还包括:
举报人员对患者方发布的众筹信息进行举报;
众筹平台根据举报人员的举报信息对患者方发布的众筹信息进行核实,若举报属实,则撤销所述众筹信息,并将该患者方的众筹账户中的捐款退还相应的捐款人。
优选的,将审核通过的众筹信息进行推广的方式包括app推广、小程序推广和朋友圈推广中的一种或多种。
优选的,基于区块链的众筹方法还包括:若捐款人无数字货币,则在众筹平台上为捐款人进行开户操作,然后根据当前的汇率将资金转换为相应的数字货币。
本发明的有益效果是:
(1)本发明中,筹款数据全部记录在区块链中,由于区块链数据不可篡改的特性,使得筹款数据公开透明,用户可以方便地查看众筹的每一笔交易记录,使得所有捐款明细公开透明,有利于消除捐款人以及患者方对于暗箱操作的顾虑;
(2)本发明的方案中,接受数字货币的捐款,从而让数字货币参与公益服务中。
附图说明
图1为基于区块链的众筹平台的组成示意图;
图2为基于区块链的众筹方法的流程示意图。
具体实施方式
下面将结合实施例,对本发明的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域技术人员在没有付出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
参阅图1-2,本发明提供一种基于区块链的众筹平台及方法:
如图1所示,基于区块链的众筹平台,包括患者模块、审核模块、推广模块、捐款模块、处理模块、查询模块、区块链模块、举报模块和核实模块等。
所述患者模块包括注册子模块、登录子模块和信息发布子模块。注册子模块用于患者方注册平台账号,注册时患者方设置相应的账户名以及登录密码,在整个筹款平台中一个账户名只能被用一次,即不能存在相同的两个账户名。登录子模块用于患者方登录所述平台账号,患者方根据账户名和登录密码登录相应的平台账号,众筹平台验证账户名和登录密码是否匹配,若匹配则成功登录相应的平台账号,否则提示登录失败。信息发布子模块用于患者方在登录所述平台账号后发布众筹信息,众筹信息包括患者方的真实个人信息、筹款原因及证明材料、筹款金额、筹款时间等。
所述审核模块用于对所述患者方发布的众筹信息进行审核,若众筹信息中存在资料不全、资料有误或者资料造假等问题,则将众筹信息直接驳回。
所述推广模块用于将审核通过的众筹信息进行发布和推广,将审核通过的众筹信息进行推广的方式包括app推广、小程序推广和朋友圈推广中的一种或多种。
所述捐款模块用于捐款人向患者方的众筹账户进行捐款。
所述处理模块包括众筹账户创建子模块、资金处理子模块和信息记录子模块等。众筹账户创建子模块用于在区块链模块中为众筹信息通过审核的患者方建立一个众筹账户。资金处理子模块用于在筹款截止后根据当前币种汇率将所述众筹账户中的资金兑换成现金流,然后将所述现金流汇到患者方的银行账户。信息记录子模块用于将患者方的众筹信息、捐款人的捐款信息和向患者方的银行账户汇款的汇款信息记录在区块链模块中。
所述查询模块用于查询人查看所述众筹信息、捐款信息和汇款信息。
所述区块链模块用于记录众筹信息、捐款信息和汇款信息,以及建立众筹账户。区块链模块记录信息的过程为:创建交易(tx);将交易(tx)通过p2p网络进行广播;对交易(tx)进行验证;将交易(tx)的验证结果通过p2p网络进行广播;将交易(tx)写入账本。
所述举报模块用于举报人对患者方发布的众筹信息进行举报。
所述核实模块用于对举报人的举报信息进行核实,若举报属实,则撤销所述众筹信息,并将该患者方的众筹账户中的捐款退还相应的捐款人。
所述基于区块链的众筹平台还包括开户模块,用于提供数字货币开户功能,捐款人若无数字货币,则可以在众筹平台上为捐款人进行开户操作,然后根据当前的汇率将资金转换为相应的数字货币。
如图2所示,基于区块链的众筹方法,包括:
s1.患者方在众筹平台上发布众筹信息。
在步骤s1之前还包括:患者方在众筹平台上注册平台账号,患者方登录所述平台账户。
s2.众筹平台对所述患者方发布的众筹信息进行审核,若审核通过则在区块链模块上为所述患者方建立一个众筹账户,并将所述患者方的众筹信息记录在区块链模块上。
s3.将审核通过的众筹信息进行发布和推广。将审核通过的众筹信息进行推广的方式包括app推广、小程序推广和朋友圈推广中的一种或多种。
s4.捐款人采用数字货币向所述患者方的众筹账户进行捐款,众筹平台将捐款人的捐款信息记录在区块链模块上。捐款人根据众筹平台提供的(众筹信息中)患者方的账户地址进行转账,转账时可以添加备注信息;转账时仅须提供患者方的账户地址,且转账出错不能撤回。
s5.在患者方筹款截止后,众筹平台根据当前的币种汇率将所述患者方的众筹账户中的资金兑换成现金流,并将所述现金流汇到患者方的银行账户中。
本实施例中,将众筹信息、捐款信息和汇款信息等记录在区块链模块中,利用利用区块链数据不可篡改的特性,避免相关信息被篡改,保证了相关记录信息的真实性。
所述基于区块链的众筹方法还包括:
查询人员通过众筹平台查看患者方的众筹信息、捐款人的捐款信息以及众筹平台向患者方的银行账户进行汇款的汇款信息。
任何人都可以通过查询模块方便地查看众筹信息、捐款信息和汇款信息等记录,做到相关信息的可追踪、可溯源,使得筹款数据公开透明,有利于消除捐款人以及患者方对于暗箱操作的顾虑。
所述基于区块链的众筹方法还包括:举报人员对患者方发布的众筹信息进行举报;众筹平台根据举报人员的举报信息对患者方发布的众筹信息进行核实,若举报属实,则撤销所述众筹信息,并将该患者方的众筹账户中的捐款退还相应的捐款人。
基于区块链的众筹方法还包括:若捐款人无数字货币,则可以在众筹平台上为捐款人进行开户操作(即为捐款人形成一个区块链钱包),然后根据当前的汇率将资金转换为相应的数字货币。
以上所述仅是本发明的优选实施方式,应当理解本发明并非局限于本文所披露的形式,不应看作是对其他实施例的排除,而可用于各种其他组合、修改和环境,并能够在本文所述构想范围内,通过上述教导或相关领域的技术或知识进行改动。而本领域人员所进行的改动和变化不脱离本发明的精神和范围,则都应在本发明所附权利要求的保护范围内。
php网站怎么接入区块链众筹
想买保时捷Cayenne?试驾来周口,首付低至20%
精选推荐
广告
Thinkphp蚂蚁大未来新版区块链系统源码.zip
24下载·0评论
2020年1月8日
区块链众筹的创想N次方
135阅读·0评论·0点赞
2018年4月17日
区块链众筹的优势
753阅读·1评论·0点赞
2018年5月24日
突破众筹困境“入主”区块链——先行者的力量
2083阅读·0评论·0点赞
2018年8月17日
众筹空间(区块链技术探索)
942阅读·3评论·0点赞
2018年5月29日
【WEB3】如何使用Web3J库开发应用连接到以太坊区块链网络
2087阅读·0评论·0点赞
2022年8月17日
帝国时代手游下载
精选推荐
广告
基于区块链技术的众筹平台-毕业设计
769阅读·0评论·0点赞
2020年5月22日
详解区块链技术,如何运作
3465阅读·0评论·1点赞
2022年7月6日
基于区块链技术的众筹平台
25下载·0评论
2018年12月18日
带你玩转区块链--实现Dapp众筹项目-第二章-第二节【以太坊篇】
1336阅读·2评论·2点赞
2020年2月21日
51行代码实现简单的PHP区块链
109阅读·0评论·0点赞
2021年2月20日
php使用区块链_PHP实现区块链
1217阅读·0评论·0点赞
2021年3月22日
区块链入门教程——什么是区块链?
1074阅读·1评论·0点赞
2018年3月1日
区块链众筹骗局
1612阅读·0评论·0点赞
2018年11月25日
怎么样加入区块链?个人如何进入区块链?
1.4W阅读·0评论·0点赞
2018年6月25日
如何让区块链连接外面的世界
9775阅读·1评论·2点赞
2016年12月20日
如何全面控制区块链上数据的“读”权限
1507阅读·0评论·0点赞
2021年10月27日
要不要接入区块链,新手看这一篇就够了
497阅读·0评论·0点赞
2018年9月25日
去首页
看看更多热门内容
Ⅶ 06-web3j的ABI
ABI是一种数据编码方案用于处理Ethereum智能合约。ABI中定义的类型和solidity是一样的。比如uint8…,uint256,int8,…,int256,bool,string,等等。
web3j的ABI模块提供了所有ABI规范支持,包括:
web3j提供的本地java类型与ABI转换如下:
请参阅各种编码/解码的 ABI单元测试 的例子。
一个完整的ABI规范在 Solidity documentation 。
这是一个非常轻量级的模块,只依赖于 Bouncy Castle 第三方库用来加密hash( Spongy Castle 在Android上)。其他希望与Ethereum ABI交互(JVM或Android)的项目会选择使用这个模块而不是编写自己的实现。
Ⅷ ETH转账的2种方式的对比
web3j支持使用以太坊钱包文件(推荐)和以太网客户端管理命令来发起一笔交易。当你创建了一个拥有以太币的账户后,你可以通过以下两种交易机制,和以太坊网络(私网/公网)交易:
这里主要讲一下 线下签名交易(Offline transaction signing) 。线下签名交易允许你使用web3j提供的钱包账户发起交易,你完全控制自己的私钥,交易发送到网络上的其它节点并广播。
线下签名交易使用 RawTransaction 对象来完成,一共有如下几步:
1、通过私钥或密码+钱包文件(keystore)来加载转账凭证Credentials
2、获取发起转账账户的nonce 值,也就是第几笔交易
3、创建 RawTransaction交易 对象
4、签名 RawTransaction 对象,也就是对交易做签名
5、发送交易( RawTransaction 对象)给节点处理。
6、获取交易哈希值TxHash
以太坊实战-再谈nonce使用陷阱: https://blog.csdn.net/wo541075754/article/details/79054937
此外,还有一种简单的转账方式
这种方式,不需要自己管理nonce。
这2种方式都是离线交易,先组装交易,然后发送到链上。
参考:
https://docs.web3j.io/getting_started.html#transactions
https://www.jianshu.com/p/6650d2a3aea9