web3j:智能合约写操作时总是抛出java.lang.ArrayIndexOutOfBoundsException错误,不知道什么问题。

我的代码如下:

String hexPrivateKey = String.format("%040x", new BigInteger(1, Config.privateKey.getBytes()));
String hexPublicKey = String.format("%040x", new BigInteger(1, Config.publicKey.getBytes()));
Credentials credentials = Credentials.create(hexPrivateKey, hexPublicKey);
DataSaver contract = DataSaver.load(
address, web3j, credentials, Contract.GAS_PRICE, Contract.GAS_LIMIT);RemoteCall transaction2 = contract.updateDocumentPayload(
BigInteger.valueOf(1), "Test");
transaction2.send();

读取操作是成功的。写入返回以下错误:

java.lang.ArrayIndexOutOfBoundsExceptionat java.lang.System.arraycopy(Native Method)at org.bouncycastle.crypto.signers.HMacDSAKCalculator.init(Unknown Source)at org.bouncycastle.crypto.signers.ECDSASigner.generateSignature(Unknown Source)at org.web3j.crypto.ECKeyPair.sign(ECKeyPair.java:46)at org.web3j.crypto.Sign.signMessage(Sign.java:52)at org.web3j.crypto.Sign.signMessage(Sign.java:40)at org.web3j.crypto.TransactionEncoder.signMessage(TransactionEncoder.java:21)at org.web3j.tx.RawTransactionManager.signAndSend(RawTransactionManager.java:102)at org.web3j.tx.RawTransactionManager.sendTransaction(RawTransactionManager.java:91)at org.web3j.tx.TransactionManager.executeTransaction(TransactionManager.java:49)at org.web3j.tx.ManagedTransaction.send(ManagedTransaction.java:83)at org.web3j.tx.Contract.executeTransaction(Contract.java:242)at org.web3j.tx.Contract.executeTransaction(Contract.java:226)at org.web3j.tx.Contract.executeTransaction(Contract.java:220)at org.web3j.tx.Contract.lambda$executeRemoteCallTransaction$3(Contract.java:259)at org.web3j.protocol.core.RemoteCall.send(RemoteCall.java:30)at com.company.api.v1.contract.ContractDocumentPayload.postDocumentPayload(ContractDocumentPayload.java:104)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)at java.lang.reflect.Method.invoke(Unknown Source)at org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory$1.invoke(ResourceMethodInvocationHandlerFactory.java:81)at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher$1.run(AbstractJavaResourceMethodDispatcher.java:144)at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:161)at org.glassfish.jersey.server.model.internal.JavaResourceMethodDispatcherProvider$TypeOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:205)at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDispatcher.java:99)at org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:389)at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:347)at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:102)at org.glassfish.jersey.server.ServerRuntime$2.run(ServerRuntime.java:326)at org.glassfish.jersey.internal.Errors$1.call(Errors.java:271)at org.glassfish.jersey.internal.Errors$1.call(Errors.java:267)at org.glassfish.jersey.internal.Errors.process(Errors.java:315)at org.glassfish.jersey.internal.Errors.process(Errors.java:297)at org.glassfish.jersey.internal.Errors.process(Errors.java:267)at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:317)at org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:305)at org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1154)at org.glassfish.jersey.servlet.WebComponent.serviceImpl(WebComponent.java:473)at org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:427)at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:388)at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:341)at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:228)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:651)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:409)at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:754)at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1376)at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)at java.lang.Thread.run(Unknown Source)

问题的解决

应该是将错误的私钥传递给webb3j来签署交易时,会将引发该异常。请看下面的例子。

正确的工作代码(带有有效私钥):

BigInteger privateKey = new BigInteger("f9c8a5d689736d881cf9b4117bbae6d935b2368f8260a25677e35d4d1eea7231", 16);
BigInteger publicKey = new BigInteger("72445fcfdeb1fff79496d7ce66089d663ff90e26", 16);
ECKeyPair pair = new ECKeyPair(privateKey, publicKey);
pair.sign("".getBytes());

相同的代码使用无效的私钥(随便添加一个数字比如a),就会抛出与你完全相同的异常:

BigInteger privateKey = new BigInteger("f9c8a5d689736d881cf9b4117bbae6d935b2368f8260a25677e35d4d1eea7231a", 16);
BigInteger publicKey = new BigInteger("72445fcfdeb1fff79496d7ce66089d663ff90e26a", 16);
ECKeyPair pair = new ECKeyPair(privateKey, publicKey);
pair.sign("".getBytes());

始终通过WalletUtils.isValidPrivateKey()WalletUtils.isValidAddress()来检查私钥和地址是否有效。

原文《以太坊常见问题和错误》中的:
http://cw.hubwiz.com/card/c/ethereum-FAQ/1/2/9/

另外推荐几个很受欢迎全网稀缺的互动教程:

  • web3j,主要是针对java和android程序员围绕web3j库进行区块链以太坊开发的讲解。
  • python以太坊,主要是针对python围绕web3.py进行区块链以太坊应用开发的讲解。
  • php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和事件等内容。
  • 以太坊开发,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
  • 以太坊教程,主要介绍智能合约与dapp应用开发,适合入门。

web3j智能合约错误:java.lang.ArrayIndexOutOfBoundsException相关推荐

  1. java.lang.arr_以太坊常见问题和错误 / java.lang.ArrayIndexOutOfBoundsException? - 汇智网...

    web3j:智能合约写操作时总是抛出java.lang.ArrayIndexOutOfBoundsException错误,不知道什么问题. 我的代码如下: String hexPrivateKey = ...

  2. Java - 错误: quot;java.lang.ArrayIndexOutOfBoundsException: length=1; index=1quot;

    错误: "java.lang.ArrayIndexOutOfBoundsException: length=1; index=1" 本文地址: http://blog.csdn.n ...

  3. java.lang.arr_jxl操作java.lang.ArrayIndexOutOfBoundsException: 441 错误的解决

    评论 # re: jxl操作java.lang.ArrayIndexOutOfBoundsException: 441 错误的解决 [未登录] 2007-04-29 20:14 Robin 不错,实践 ...

  4. ArrayMap java.lang.ArrayIndexOutOfBoundsException

    错误堆栈: java.lang.ArrayIndexOutOfBoundsException: length=0; index=1at android.support.v4.util.SimpleAr ...

  5. java.lang.ArrayIndexOutOfBoundsException异常分析及解决

    2019独角兽企业重金招聘Python工程师标准>>> java.lang.ArrayIndexOutOfBoundsException异常分析及解决 这是一个非常常见的异常,从名字 ...

  6. Tomcat 或JBOSS java.lang.ArrayIndexOutOfBoundsException: 8192 解决方案【转】

    错误信息: 2017-1-17 10:09:39 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() ...

  7. java.lang.arrayindexoutofboundsexception: Index 13 out of bounds for length 13

    java.lang.arrayindexoutofboundsexception: Index 13 out of bounds for length 13(数组越界) 当你使用不合法的索引访问数组时 ...

  8. Exception in thread main java.lang.ArrayIndexOutOfBoundsException: 4 at text.Division.main(Divisi

    这是个初学者非常容易遇到的问题,下面请看源代码: public class Division {public static void main(String[] args) {String str = ...

  9. java arraymap_ArrayMap java.lang.ArrayIndexOutOfBoundsException

    错误堆栈: java.lang.ArrayIndexOutOfBoundsException: length=0; index=1 at android.support.v4.util.SimpleA ...

最新文章

  1. SPI初始化C语言编程,SD卡spi模式读写,初始化和复位都成功了
  2. bootcmd和bootargs
  3. python3.7下载tensorflow_【AI初体验】在anaconda中python3.7版本安装Tensorflow 与 Keras来玩玩...
  4. 湍流退化图像复原如何使用matlab,湍流退化图像复原技术研究现状及展望
  5. python collections(容器)模块
  6. 4024-砾石的交换排序(C++,附思路)
  7. 使用Jenkins在Azure Web App上进行ASP.NET Core应用程序的持续集成和部署(CI/CD)–第4天
  8. SpringBoot定时器
  9. Windows Server 2003 R2标准版 SP2 64位 (简体中文)官方原版ISO镜像
  10. 老华为交换机S3500配置SSH
  11. 纪念自己初中的住宿生活
  12. 如何破解锐捷支持多网卡
  13. 电信 宽带 光猫 中兴 F460 V6.0.0P11T2sc 破解 telecomadmin 超级密码 的方法
  14. Sqli-Lab实验环境搭建(phpstudy环境安装、火狐浏览器插件安装、sqlmap安装、Sqli-Lab安装)
  15. 读书·2018(14本)
  16. 深度学习及机器学习整理--多谢各个网络大神
  17. 使用Visual Studio怎样制作登录界面
  18. 推出 BlazePose:实现设备端实时人体姿态追踪
  19. 白手起家学习使用flex (5) 在Flash Builder5 中引用 fla 文件中的类( symbol )
  20. 【资源】谷歌logo的配色的RGB值

热门文章

  1. c920摄像头驱动 linux,4G模块驱动 - PanGuBoard - 湃兔核i2SOM
  2. AbsoluteLayout xiantu
  3. 根据交换机端口分配固定地址的方法
  4. 微软借“云”掀估值高涨浪潮,百度借智能云启动千亿美金估值航母?
  5. windows 网管总结
  6. 备考计算机软件,2018年计算机软件水平考试备考心得
  7. HVDC电力系统simulink仿真
  8. linux与centos的关系
  9. win7 用软碟通装ubuntu双系统
  10. [PHP] 高并发 php uniqid 不重复唯一标识符生成方案