我能够在我的Java桌面环境中生成一个公钥,我得到了类似的东西
Sun RSA public key, 1024 bits modulus: 101700973019391285593457598101942678753508114287289699162184623605939671495532511783006850112834969917970271633181351680298749946797462542179729127916916336425952724141383800466274935950042225686754068132826643586090512962724382324158485291344703936377718522573879330753020035687831145457530843148690890911921 public exponent: 65537
但是在Android设备上,当我将密钥作为字符串获取并使用KeyFactory
生成公钥时,我得到了这个:
OpenSSLRSAPublicKey{modulus=90d3b5cefc50dc42828cee8d718876f7573b4c9287dddf808e73cb66266c2004165217f86d0f0192de0bb88b3aac2002303ee8b1c926e9bc54189a5ec5a12bb293df0b3c6ff2458a63098f712f0b72218ce301c38de3971ae8c6c646160a5e2e24dc07679e5a82ada1233ecf5eca3d0d1f483d1c9f059 a23deed537c670b70b1,publicExponent=10001}
钥匙有差异。我试过SpongyCastle。我仍然在Android上获得OpenSSL结果。
我错过了什么?
答案 0 :(得分:4)
键之间没有差异。一个以16(十六进制)打印,而另一个以十进制打印。只需尝试以下代码即可获得保证:
BigInteger bi = new BigInteger(
"90d3b5cefc50dc42828cee8d718876f7573b4c9287dddf808e73cb66266c2004165217f86d0f0192de0bb88b3aac2002303ee8b1c926e9bc54189a5ec5a12bb293df0b3c6ff2458a63098f712f0b72218ce301c38de3971ae8c6c646160a5e2e24dc07679e5a82ada1233ecf5eca3d0d1f483d1c9f059a23deed537c670b70b1",
16);
System.out.println(bi.toString(10));
结果与非OpenSSL密钥相同。
这里发生的是您的不同平台具有执行加密操作的不同加密提供程序。结果将是相同的,但会有一些小的特性会被注意到,例如,在调用toString()
时。