Java 接入 SDK
毕竟都是一个体系的 其实 Java Android API 差别不大
Java Version 8+
Maven <dependency> <groupId>org.web3j</groupId> <artifactId>core</artifactId> <version>3.4.0</version> </dependency> Gradle compile ('org.web3j:core:3.4.0')
Android 接入 SDK
Maven <dependency> <groupId>org.web3j</groupId> <artifactId>core</artifactId> <version>3.3.1-android</version> </dependency> Gradle compile ('org.web3j:core:3.3.1-android') //引入RxAndroid compile 'io.reactivex:rxandroid:1.2.1'
初始化项目
无论是 Java Android 都有一个 Web3j 的接口
先初始化这个接口
//SERVICE_IP 这个是测试网地址 或者你的私有链地址 //私有链的话 一般带上端口号比如我的私有链是:http://127.0.0.1:8545 //如果是从infura.io注册的测试网的话 不需要加端口号 例如 https://ropsten.infura.io/your-token Java Web3j web3j = Web3j.build(new HttpService(SERVICE_IP)); Android Web3j web3j = JsonRpc2_0Web3j(new HttpService(SERVICE_IP));
同步调用 API
这里举例获取 ETH 客户端版本 API
同步调用的话 Java Android 都一样
//两种方式 都是同步 具体细节没有去研究过 Web3ClientVersion web3ClientVersion = web3j.web3ClientVersion().send(); Web3ClientVersion web3ClientVersion = web3j.web3ClientVersion().sendAsync().get(); String version = web3ClientVersion.getWeb3ClientVersion();
异步调用
得益于 RxJava 让我们异步调用更简洁 更方便
因为 Android 的特性 子线程不可更改 UI 所以 Android 方面 有点不一样
Java: web3j.web3ClientVersion() .observable() .observeOn(Schedulers.io()) .subscribe(new Subscriber<Web3ClientVersion>() { @Override public void onStart() { super.onStart(); System.out.println("onStart:" + Thread.currentThread()); } @Override public void onCompleted() { System.out.println("onCompleted:" + Thread.currentThread()); } @Override public void onError(Throwable e) { e.printStackTrace(); System.out.println("onError:" + Thread.currentThread()); } @Override public void onNext(Web3ClientVersion web3ClientVersion) { System.out.println("onNext:" + Thread.currentThread()); System.out.println("web3ClientVersion:" + web3ClientVersion.getWeb3ClientVersion()); } }); //最后输出 onStart:Thread[main,5,main] //主线程 onNext:Thread[RxIoScheduler-2,5,main] //IO线程 web3ClientVersion:Geth/v1.8.3-stable/linux-amd64/go1.10 //ETH客户端版本 onCompleted:Thread[RxIoScheduler-2,5,main] //IO线程 Android: web3j.web3ClientVersion() .observable() .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(new Subscriber<Web3ClientVersion>() { @Override public void onStart() { super.onStart(); System.out.println("onStart:" + Thread.currentThread()); } @Override public void onCompleted() { System.out.println("onCompleted:" + Thread.currentThread()); } @Override public void onError(Throwable e) { e.printStackTrace(); System.out.println("onError:" + Thread.currentThread()); } @Override public void onNext(Web3ClientVersion web3ClientVersion) { System.out.println("onNext:" + Thread.currentThread()); System.out.println("web3ClientVersion:" + web3ClientVersion.getWeb3ClientVersion()); } }); //subscribeOn(Schedulers.io()) 用IO线程执行耗时操作 //observeOn(AndroidSchedulers.mainThread()) 在观察者回调的时候 使用Android 主线程回调
获取账户余额
//address 账户地址 EthGetBalance send = web3j.ethGetBalance(address, DefaultBlockParameterName.LATEST).send(); // 默认获取到的单位是WEI 转换为ETH BigDecimal balance = Convert.fromWei(send.getBalance().toString(), Convert.Unit.ETHER);
区块链高度
BigInteger blockNumber = web3j.ethBlockNumber().send().getBlockNumber();
区块详情
DefaultBlockParameterNumber defaultBlockParameterNumber = new DefaultBlockParameterNumber(blockNumber); EthBlock send = web3j.ethGetBlockByNumber(defaultBlockParameterNumber, true).send(); EthBlock.Block block = send.getBlock();
创建以太坊地址
String newWalletFile = WalletUtils.generateNewWalletFile(password, walletFolder, false); //password 钱包文件密码 //walletFolder 钱包文件存储目录 //false 不进行加密 (如果加密 内存开销很大)
加载凭证
凭证是指 一个账户地址的凭证 可以通过私钥直接加载 或者通过密码 和私钥文件加载 (私钥文件是指keystore目录下的加密文件)
私钥加载凭证
Credentials credentials = Credentials.create(privateKey);
私钥文件加载凭证
//password 密码 filePath私钥路径 Credentials credentials = WalletUtils.loadCredentials(password, filePath);
通过凭证 取出地址和私钥
ECKeyPair ecKeyPair = credentials.getEcKeyPair(); String address = "0x" + ecKeyPair.getPublicKey().toString(16); String privateKey = "0x"+ecKeyPair.getPrivateKey().toString(16); //address 以太坊地址 //privateKey 私钥
其他的 API 自己摸索吧
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于