我正在尝试在 Android 应用程序中实现 RSA 算法。我正在使用该java.math.BigInteger.modPow()
功能进行加密/解密,该功能适用于我的计算机(Windows 和 Xubuntu)和我的 Raspberry Pi(也是 Debian)。当在我的手机(Android 4.4.4)上执行相同的代码时,在第二次调用时会引发以下异常modPow()
:
java.jang.ArithmeticException: error:0306B06B:bignum routines:BN_div:not initialized
at java.math.NativeBN.BN_mod_exp(NativeMethod)
at java.math.BigInt.modExp(BigInt.java:327)
at java.math.BigInteger.modPow(BigInteger.java:997)
at "where I call java.math.BigInteger.modPow()"
我检查了指数和模数:两者都是正数,所以文档并没有真正帮助。减小键的大小(指数和模数)也没有改变任何东西。不幸的是,我找不到本机功能的来源,并且不知道可能发生了什么。
你知道为什么会抛出这个异常或者错误代码应该是什么意思吗?