文件名称 | 版本号 | 作者 | 版本 | |
---|---|---|---|---|
逐浪_以太坊_v0.0.1 | v0.0.1 | 若布与宫合 | 8416837 |
充值
充token
虚拟币
①点击充值
②github授权登录;
③找到消息框,贴上待充值地址(由下文API生成),如:0x91b5156102ba620c515d0f3393f8642fb49e7227
,发送消息,之后等待充值,好像每周可以充一次。
客户端
根据账号密码(用户信息)生成私钥
SHA256演示
在线编码演示
但是生成私钥最好是自己写代码生成
Java版 节选代码需修整 部分工具包需要引入依赖
- 引入依赖xml
- 生成私钥、公钥
import com.abc.gateway.sdk.algorithm.Sha256;
import org.web3j.crypto.*;
import org.web3j.utils.Numeric;
/**
* 功能描述: 根据用户信息生成私钥、公钥、地址Map
*
* @param: [username, salt:盐值, password]
* @return: java.lang.String
* @author: cc
* @date: 2020/1/9 8:29:05
*/
public static AccountDTO generateBlockChainAccount(String username, String salt, String password) throws Exception {
AccountDTO accountDTO = new AccountDTO();
log.debug("{} === {}", "salt", salt);
StringJoiner privateKeyOrigin = new StringJoiner("")
.add(username)
.add(salt)
.add(password);
log.debug("{} === {}", "原始私钥(种子)", privateKeyOrigin);
// 执行SHA256
String privateKey = Sha256.getSHA256(privateKeyOrigin.toString(), "ascii");
log.debug("{} === {}", "私钥", privateKey);
String address = Credentials.create(privateKey).getAddress();
log.debug("{} === {}", "根据私钥生成地址", address);
String publicKey = String.valueOf(Credentials.create(privateKey).getEcKeyPair().getPublicKey());
log.debug("{} === {}", "根据私钥生成公钥", publicKey);
accountDTO.setPrivateKey(privateKey);
accountDTO.setAddress(address);
accountDTO.setPublicKey(publicKey);
return accountDTO;
}
说明
私钥算出公钥,公钥算出地址,当然不可以逆推,
因此私钥需保密,地址可以公开。比如,按上文地址充值虚拟币的时候需要提供地址。
上链 调用智能合约
- 调API生成未签名交易结构体,是16进制字符串,这涉及到序列化&反序列化;
- 签名。如果上一步返回成功,那么可以对结构体进行签名;
- 将签名和结构体作为请求参数,调用API,以期返回成功。
权限
- 合约账户部署合约
- 外部账户调用智能合约