【问题标题】:Different RSA public key generated on AndroidAndroid 上生成的不同 RSA 公钥
【发布时间】:2013-09-25 19:08:50
【问题描述】:

我能够在我的 Java 桌面环境中生成一个公钥,我得到了类似的东西

Sun RSA public key, 1024 bits modulus: 101700973019391285593457598101942678753508114287289699162184623605939671495532511783006850112834969917970271633181351680298749946797462542179729127916916336425952724141383800466274935950042225686754068132826643586090512962724382324158485291344703936377718522573879330753020035687831145457530843148690890911921 public exponent: 65537

但在 Android 设备上,当我将密钥作为字符串并使用 KeyFactory 生成公钥时,我得到了这个:

OpenSSLRSAPublicKey{modulus=90d3b5cefc50dc42828cee8d718876f7573b4c9287dddf808e73cb66266c2004165217f86d0f0192de0bb88b3aac2002303ee8b1c926e9bc54189a5ec5a12bb293df0b3c6ff2458a63098f712f0b72218ce301c38de3971ae8c6c646160a5e2e24dc07679e5a82ada1233ecf5eca3d0d1f483d1c9f059 a23deed537c670b70b1,publicExponent=10001}

密钥存在差异。我试过 SpongyCastle。我仍然在 Android 上获得 OpenSSL 结果。

我错过了什么?

【问题讨论】:

    标签: java android openssl rsa spongycastle


    【解决方案1】:

    密钥之间没有差异。一个以 base-16(十六进制)打印,而另一个以十进制打印。请尝试以下代码以确保安全:

    BigInteger bi = new BigInteger(
        "90d3b5cefc50dc42828cee8d718876f7573b4c9287dddf808e73cb66266c2004165217f86d0f0192de0bb88b3aac2002303ee8b1c926e9bc54189a5ec5a12bb293df0b3c6ff2458a63098f712f0b72218ce301c38de3971ae8c6c646160a5e2e24dc07679e5a82ada1233ecf5eca3d0d1f483d1c9f059a23deed537c670b70b1",
        16);
    System.out.println(bi.toString(10));
    

    结果将与您的非 OpenSSL 密钥相同。

    这里发生的情况是,您的不同平台有不同的加密提供程序来执行加密操作。结果将是相同的,但会有一些小的特性会引起注意,例如,在调用 toString() 时。

    【讨论】:

    • 从来没想过!我不得不在设备和后端使用不同的实现(海绵城堡)。谢谢邓肯