好久没更新博客了.主要是最近在研究区块链技术 (炒币),当然也成为了一个小矿工,挖迅雷的玩客币.不过前不久,迅雷宣布将停止国内转账,而在 31 号的时候,大陆 ip 就无法进行转账.嗨呀我这个暴脾气啊.不让转那我就只能分析下钱包了
链克介绍
链克(英文名 LinkToken)(原来叫玩客币) 是玩客云共享计算生态下的基于区块链技术的原生数字资产,它的产生过程与玩客云智能硬件,共享 CDN 的经济应用有强关联,必须通过玩客云智能硬件分享网络带宽,存储空间等资源来获得.在玩客云共享计算生态系统中,它将成为用户交换可共享计算资源的媒介,保证用户的权益和提供的计算资源对等.
链克是基于以太坊的一种代币,交易相关的和以太坊类似,只是链克并不在以太坊公链上.所以无法使用以太坊的协议进行转账,通过抓包发现链克使用迅雷自有的服务器转账,但是协议和以太坊相似,算法也基本一致,本文只简单分析流程.算法使用以太坊的开源库.想更深入了解,可以研究以太坊的协议
给大家推荐一个视频.很好的介绍了区块链,看过了就很好理解下面的加密了
前往观看
开源项目
github.com/WrBug/wkcwa...
后面的算法将结合这个项目
START
转账流程
step1 钱包文件 + 密码 解密 com.wrbug.wkcwallet.wallet.Trade 45 行
step2 获取交易次数 com.wrbug.wkcwallet.wallet.Trade 109 行
step3 获取 gas,gasLimit
step4 对上面参数进行加密.并且用钱包签名 com.wrbug.wkcwallet.wallet.Trade 75 行
step5 获取 hash,请求支付
转账分析
转账需要钱包文件,钱包密码,转账地址和转账数量 转账前,需要对钱包文件进行解密,密码错误无法获取.解密成功,获取到 wallet 对象.
wallet = CommonWallet.fromV3(keystore, password);
链克钱包使用的是 v3 版本,获取成功后,请求获取交易次数的接口,获取到该钱包地址的交易次数,将交易次数 + 1 作为加密的一个参数,代码中参数为 txInd ,接下来获取 gas 和 gasLimit,在链克转账中.这两个为固定参数
其他币种可以通过 eth_gasPrice 接口获取,一般情况 gas 跟转账速度有直接关系.然后将转账数量进行一次转换
BigInteger gasLimit = new BigInteger("186a0", 16);
BigInteger gasPrice = new BigInteger("174876e800", 16);
BigInteger amount = Unit.valueOf(Unit.ether.toString()).toWei(String.valueOf(tradeAmount));
获取到这些参数后.需要对其进行加密.获取到 Transaction 的一个对象,并用 wallet 进行签名
最后调用 tx.getEncoded 方法获取到加密的 hash,请求服务器进行支付即可
Transaction tx = Transaction.create(toAddress.replace("0x", ""), amount, nonce, gasPrice, gasLimit, null);
tx.sign(wallet);
byte[] encoded = tx.getEncoded();
[附录] 链克协议
链克余额
请求地址
链克交易记录
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 值
来源: https://juejin.im/post/5a7460ecf265da4e82631d79