试图与web3j(Android)取得平衡,出现nullpointer异常

时间:2018-06-30 01:47:16

标签: java android web3-java

努力使任何东西都可以在android上的web3j中工作,尝试使用本示例(我已替换了token和addr),我使用的地址中确实包含一些rinkeby ETH。在电话上测试,加载此类/活动时应用程序崩溃,代码在oncreate方法中。在清单中打开Internet权限,然后在构建gradle中编译android web3j。

 Web3j web3 = Web3jFactory.build(new 
 HttpService("https://rinkeby.infura.io/token"));

    EthGetBalance ethGetBalance = null;
    try {
        ethGetBalance = web3
                .ethGetBalance("addr",DefaultBlockParameterName.LATEST)
                .sendAsync()
                .get();
    } catch (InterruptedException e) {
        e.printStackTrace();
    } catch (ExecutionException e) {
        e.printStackTrace();
    }

    BigInteger wei = ethGetBalance.getBalance();

错误

06-30 02:15:47.115 18904-18904/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.test.user.test, PID: 18904
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.test.user.test/com.test.user.test.balance}: java.lang.NullPointerException
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2548)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2607)
    at android.app.ActivityThread.access$900(ActivityThread.java:174)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1325)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:146)
    at android.app.ActivityThread.main(ActivityThread.java:5756)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:515)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
    at dalvik.system.NativeStart.main(Native Method)
 Caused by: java.lang.NullPointerException
    at com.test.user.test.balance.onCreate(balance.java:43)
    at android.app.Activity.performCreate(Activity.java:5619)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2512)

错误引用的第43行是我提交的代码中的最后一行代码。当我注释掉该行应用程序不会崩溃时,只会收到一些(我认为是全部)警告。

3 个答案:

答案 0 :(得分:2)

您的ethGetBalance返回一个空值。我认为您输入了无效的地址。那就是为什么方法 web3j.ethGetBalance失败。尝试使用有效的地址。

    Web3j web3 = Web3jFactory.build(new HttpService("https://ropsten.infura.io/your-token"));

    String strAddress="0x24b********************"; //strAddress is your wallet address
    EthGetBalance ethGetBalance=
    web3.ethGetBalance(strAddress,DefaultBlockParameterName.LATEST).sendAsync().get();

    BigInteger wei = ethGetBalance.getBalance();

ethGetBalance.getBalance()用于获取wei中的以太币余额。 要在您的钱包中获取实际令牌,请使用此Conversion方法。

  java.math.BigDecimal tokenValue = Convert.fromWei(String.valueOf(wei), Convert.Unit.ETHER);
  String strTokenAmount = String.valueOf(tokenValue);

答案 1 :(得分:0)

ethGetBalance = web3.ethGetBalance(public_address,DefaultBlockParameterName.LATEST).sendAsync()。get(); BigInteger wei = ethGetBalance.getBalance();  Log.e(“ ether balance”,“ wei” + wei); 在我的可在Playstore上使用的应用中,此功能正常运行

https://play.google.com/store/apps/details?id=multi.erc20.devgenesis.token.wallet

答案 2 :(得分:0)

问题在于,当您要访问ethGetBalance时,该方法为null,因为方法web3j.ethGetBalance失败。

您正在发送“ addr”作为地址,这不是有效的以太坊地址。

有效的以太坊地址的格式类似于以0x开头,然后包含40个元素(数字0-9或字母A至F)。 要查看您的地址是否存在,只需尝试在网站https://etherscan.io/

中找到它

尝试使用正确的以太坊地址,它应该可以工作。

EthGetBalance ethGetBalance = web3j
                    .ethGetBalance(userAddress, DefaultBlockParameterName.LATEST)
                    .sendAsync()
                    .get();


BigInteger wei = ethGetBalance.getBalance();