博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
手撸一款第三方链克钱包
阅读量:6300 次
发布时间:2019-06-22

本文共 3064 字,大约阅读时间需要 10 分钟。

好久没更新博客了。主要是最近在研究区块链技术(炒币),当然也成为了一个小矿工,挖迅雷的玩客币。不过前不久,迅雷宣布将停止国内转账,而在31号的时候,大陆ip就无法进行转账。嗨呀我这个暴脾气啊。不让转那我就只能分析下钱包了

更多精彩文章请关注:

链克介绍

链克(英文名LinkToken)(原来叫玩客币)是玩客云共享计算生态下的基于区块链技术的原生数字资产,它的产生过程与玩客云智能硬件、共享CDN的经济应用有强关联,必须通过玩客云智能硬件分享网络带宽、存储空间等资源来获得。在玩客云共享计算生态系统中,它将成为用户交换可共享计算资源的媒介,保证用户的权益和提供的计算资源对等。

链克是基于以太坊的一种代币,交易相关的和以太坊类似,只是链克并不在以太坊公链上。所以无法使用以太坊的协议进行转账,通过抓包发现链克使用迅雷自有的服务器转账,但是协议和以太坊相似,算法也基本一致,本文只简单分析流程。算法使用以太坊的开源库。想更深入了解,可以研究以太坊的协议

给大家推荐一个视频。很好的介绍了区块链,看过了就很好理解下面的加密了

开源项目

后面的算法将结合这个项目

START

转账流程

  • step1 钱包文件 + 密码 解密
  • step2 获取交易次数
  • step3 获取 gas,gasLimit
  • step4 对上面参数进行加密。并且用钱包签名
  • step5 获取hash,请求支付

转账分析

转账需要钱包文件,钱包密码,转账地址和转账数量 转账前,需要对钱包文件进行解密,密码错误无法获取。解密成功,获取到wallet对象。

wallet = CommonWallet.fromV3(keystore, password);复制代码

链克钱包使用的是v3版本,获取成功后,请求获取交易次数的接口,获取到该钱包地址的交易次数,将交易次数+1作为加密的一个参数,代码中参数为 txInd ,接下来获取gas和gasLimit,在链克转账中。这两个为固定参数

BigInteger gasLimit = new BigInteger("186a0", 16);BigInteger gasPrice = new BigInteger("174876e800", 16);复制代码

其他币种可以通过 eth_gasPrice 接口获取,一般情况gas跟转账速度有直接关系。然后将转账数量进行一次转换

BigInteger amount = Unit.valueOf(Unit.ether.toString()).toWei(String.valueOf(tradeAmount));复制代码

获取到这些参数后。需要对其进行加密。获取到Transaction的一个对象,并用wallet进行签名

Transaction tx = Transaction.create(toAddress.replace("0x", ""), amount, nonce, gasPrice, gasLimit, null);tx.sign(wallet);byte[] encoded = tx.getEncoded();复制代码

最后调用tx.getEncoded方法获取到加密的hash,请求服务器进行支付即可

[附录]链克协议

链克余额

请求地址

https://walletapi.onethingpcs.com

Method

POST

Header

Content-Type:application/json

Body
{	"jsonrpc": "2.0",	"method": "eth_getBalance",	"params": ["0xe6637d20b74b7cce17d8eacf8516e85ee646fe74", "latest"],	"id": 1}//0xe6637d20b74b7cce17d8eacf8516e85ee646fe74 为钱包地址复制代码
Response
{	"jsonrpc": "2.0",	"id": 1,	"result": "0x0"}//result 为16进制余额,需要处理,祥见代码复制代码

链克交易记录

请求地址

https://walletapi.onethingpcs.com

Method

POST

Header

Content-Type:application/json

Body
["0xe6637d20b74b7cce17d8eacf8516e85ee646fe74", "0", "0", "1", "10"]//0xe6637d20b74b7cce17d8eacf8516e85ee646fe74 为钱包地址复制代码
Response
{	"totalnum": 73646,	"result": [{		"timestamp": "1517381448",		"type": 1,		"tradeAccount": "0x625251ec47f46e35edb1c2dde31c1711d7c3e4ce",		"amount": "0xa80d24677efef00000",		"cost": "0x0",		"hash": "0x5c9d52cba04dce07fa7fe63a9d7c1fd50bf0f72392309fb1d44dd9a3de4797a7",		"title": "",		"extra": "",		"order_id": "20180131145048tppfbj0qty8odx5v"	}]}//result 为每条交易记录复制代码

链克交易次数

请求地址

https://walletapi.onethingpcs.com

Method

POST

Header

Content-Type:application/json

Body
{	"jsonrpc": "2.0",	"method": "eth_getTransactionCount",	"params": ["0xe6637d20b74b7cce17d8eacf8516e85ee646fe74", "pending"],	"id": 1}//0xe6637d20b74b7cce17d8eacf8516e85ee646fe74 为钱包地址复制代码
Response
{	"jsonrpc": "2.0",	"id": 1,	"result": "0x9"}复制代码

发起一次交易

请求地址

https://walletapi.onethingpcs.com

Method

POST

Header

Content-Type: application/json NC: IN

Body
{	"jsonrpc": "2.0",	"method": "eth_sendRawTransaction",	"params": ["0xf86d0985174876e...c3a7753869946bfe21ef822ee72d3a8218d4"],	"id": 1,	"Nc": "IN"}//0xf86d0985174876e...c3a7753869946bfe21ef822ee72d3a8218d4 一次交易的hash值复制代码
Response
{	"jsonrpc": "2.0",	"id": 1,	"result": "0x****"}//成功后返回 交易成功的hash值复制代码

转载地址:http://lzwxa.baihongyu.com/

你可能感兴趣的文章
Docker 自定义SSH服务镜像
查看>>
JavaScript强化教程 —— Cocos2d-JS自动JSB绑定规则修改
查看>>
configure: error: in `/root/httpd-2.2.11/srclib/apr': c
查看>>
CentOS7搭建Kubernetes-dashboard管理服务
查看>>
我的友情链接
查看>>
文件管理系统的学习
查看>>
邮件服务器_安装准备和安装之七_(Windows Server 2008 R2 SP1英文版)
查看>>
A段架構師的關鍵思考技術:戰術引導戰略
查看>>
主板模式的两项<通用性>接口
查看>>
Nginx & PCRE 安装问题
查看>>
hdu1269模板tarjan
查看>>
开发任意网站Android客户端
查看>>
通过WindowsXPMode,Win7下照样使用IE8
查看>>
4. 异常的处理
查看>>
popToViewController的奇异用法
查看>>
static关键字(二)
查看>>
开放寻址法
查看>>
buildroot下查找外部编译器通过ext-toolchain-wrapper调用的参数
查看>>
MySQL Replication 主主配置详细说明
查看>>
Linux的任务调度
查看>>