在.NET中,我生成了以下公共密钥文件:
<RSAKeyValue>
<Modulus>xTSiS4+I/x9awUXcF66Ffw7tracsQfGCn6g6k/hGkLquHYMFTCYk4mOB5NwLwqczwvl8HkQfDShGcvrm47XHKUzA8iadWdA5n4toBECzRxiCWCHm1KEg59LUD3fxTG5ogGiNxDj9wSguCIzFdUxBYq5ot2J4iLgGu0qShml5vwk=</Modulus>
<Exponent>AQAB</Exponent>
</RSAKeyValue>
.NET很高兴使用其常规方法进行加密。
我正在尝试使用此密钥在Java中编码字符串。当我尝试加密字符串时,我遇到了算术异常。
以下是我用来加密的代码:
byte[] modulusBytes = Base64.decode(this.getString(R.string.public_key_modulus));
byte[] exponentBytes = Base64.decode(this.getString(R.string.public_key_exponent));
BigInteger modulus = new BigInteger( modulusBytes );
BigInteger exponent = new BigInteger( exponentBytes);
RSAPublicKeySpec rsaPubKey = new RSAPublicKeySpec(modulus, exponent);
KeyFactory fact = KeyFactory.getInstance("RSA");
PublicKey pubKey = fact.generatePublic(rsaPubKey);
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, pubKey);
byte[] cipherData = cipher.doFinal( new String("big kitty dancing").getBytes() );
这是代码块中的最后一行失败。
我看了很多例子,这是我能想到的最好的例子。如果不明显,则R.string.public_key_modulus是Modulus元素中文本的复制/粘贴,同样适用于指数。
我做错什么了?
最佳答案
试试这个:
BigInteger modulus = new BigInteger(1, modulusBytes );
BigInteger exponent = new BigInteger(1, exponentBytes);
否则,您最终会得到负模数。
BigInteger(byte[])
构造函数假定一个带符号的big-endian表示形式。 BigInteger(int, byte[])
构造函数使用提供的符号位(此处的“1”表示“正”)。另外,请小心
String.getBytes()
,它使用平台“默认字符集”,该平台取决于运行应用程序的计算机的配置。如果您想要可重现的结果,最好指定一个明确的字符集(例如"UTF-8"
)。