gpt4 book ai didi

java - 使用具有给定模数和指数的 RSA 算法在 Android 中加密

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:11:06 24 4
gpt4 key购买 nike

我以前在 C# 中使用 RSACryptoServiceProvider 来加密一些数据,现在我必须在 Android 程序中复制这种加密。我希望我的 Android 程序生成与我在 C# 程序中获得的结果相同的结果。

公钥:

<RSAKeyValue>
<Modulus>zz4qdc39y1BHyJgVXUkINJSbsUd1ZJPISyE9nNGjqgR+ZO1a4cE3ViVCSZCw+6dBdVMFNjzZPBxl0mT57GIq7rcuoT0scesZgxOftbMasPbxp0BGrh3HTpbBMJdCopgcYV98CZERakb8Pgbb0ne/DiW9Aq0kfTBE02/iEHRNuqMNfo1GFo55m0OKbxVoM6UBb8AITQ6lbdvfCgeIvMzRlVrHCwxUNrrX5cS6gurEfJ8Da+prKQmwWpFCkwDkPWje2W+bTSPUc9l6Ads0UimYE5sGs4Zsfz6Eocz4rJjR+qCiB8qt6HtdyjKo0auqYzyXIjdRv2950flc9tOh5bRlQQ==
</Modulus>
<Exponent>AQAB</Exponent>
</RSAKeyValue>

Java 加密程序:

byte[] modulusBytes = Base64.decode(Modoutput.getBytes("UTF-8"),
Base64.DEFAULT);
byte[] exponentBytes = Base64.decode(Expoutput.getBytes("UTF-8"),
Base64.DEFAULT);
BigInteger e = new BigInteger(1, exponentBytes);
BigInteger m = new BigInteger(1, modulusBytes);
RSAPublicKeySpec keySpec = new RSAPublicKeySpec(m, e);
KeyFactory fact = KeyFactory.getInstance("RSA");
PublicKey pubKeyn = fact.generatePublic(keySpec);

Log.i("Publickey", pubKeyn.toString());
Cipher cipher = Cipher.getInstance("RSA/ECB/NoPadding");
cipher.init(Cipher.ENCRYPT_MODE, pubKeyn);
byte[] encryptedByteData = cipher.doFinal(byteData);
String outputEncrypted = Base64.encodeToString(encryptedByteData,
Base64.NO_WRAP);

Log.i("Encrypteddata", outputEncrypted);

我尝试了上面的代码,但它给出了与 C# 完全不同的输出。谁能告诉我我的代码有什么问题?提前致谢。


编辑:根据要求,这是我试图用 Java 复制加密输出的 C# 代码:

public static string EncryptText(string text, int keySize,
string publicKeyXml) {
var encrypted = Encrypt(Encoding.UTF8.GetBytes(text), keySize,
publicKeyXml);
return Convert.ToBase64String(encrypted);
}

public static byte[] Encrypt(byte[] data, int keySize, string publicKeyXml) {
if (data == null || data.Length == 0)
throw new ArgumentException("Data are empty", "data");
int maxLength = GetMaxDataLength(keySize);
if (data.Length > maxLength)
throw new ArgumentException(String.Format(
"Maximum data length is {0}", maxLength), "data");
if (!IsKeySizeValid(keySize))
throw new ArgumentException("Key size is not valid", "keySize");
if (String.IsNullOrEmpty(publicKeyXml))
throw new ArgumentException("Key is null or empty", "publicKeyXml");

using (var provider = new RSACryptoServiceProvider(keySize)) {
provider.FromXmlString(publicKeyXml);
return provider.Encrypt(data, _optimalAsymmetricEncryptionPadding);
}
}

最佳答案

根据定义,加密试图隐藏有关纯文本的所有信息。这包括有关相同纯文本的信息。为此,它在各种填充模式中使用某种随机数(例如 PKCS#1 v1.5 兼容填充或 RSA 的 OAEP 填充)。因此,从密码学的角度来看,如果您得到相同的结果,则该实现已损坏

检验密文是否正确的方法是用私钥解密。如果这导致您开始使用明文,那么您的实现是正确的。

[编辑] 请注意,您在 C# 代码中使用 OAEP 加密,而 Java 默认使用 PKCS#1 v1.5 兼容方案。您应该使用 "RSA/None/OAEPWithSHA1AndMGF1Padding""RSA/ECB/OAEPWithSHA1AndMGF1Padding"。如果它不可用,请添加 Bouncy CaSTLe 提供商。

关于java - 使用具有给定模数和指数的 RSA 算法在 Android 中加密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15270859/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com