- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想在c#中用rsa加密和解密数据。我写了这段代码,它可以很好地加密,但我在解密时遇到了问题。我的问题是什么?!
这是我的代码:
using System;
using System.Security.Cryptography;
using System.IO;
using System.Text;
namespace Cry
{
public class CryptoUtils
{
public CryptoUtils ()
{
UnicodeEncoding ByteConverter = new UnicodeEncoding();
byte[] dataToEncrypt = ByteConverter.GetBytes("Data to Encrypt");
byte[] encryptedData;
byte[] decryptedData;
string decrptedStr = "";
var pub = Convert.FromBase64String("MCgCIQCfkl4xV5T/v3r1bifOc1mVHa9yak5pGjUfAv0r+s6+AwIDAQAB");
var prv = Convert.FromBase64String("MIGsAgEAAiEAn5JeMVeU/7969W4nznNZlR2vcmpOaRo1HwL9K/rOvgMCAwEAAQIg\nMce6pM/6xpIYrMoxluE7JBkVe9Sme9d6NPPJJX3NyBECEgCmwIarl1hSBnTqZNwJ\n8hZhqwIQAPT6CO/l/ma1sDi7eM7tCQISAKH90lYLlr9IinfSN3hp95g1AhAAlyNf\nuioqX1G+y/GVogyJAhEmQQB52juSQ574HnampzXUpQ==");
using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider()) {
RSAParameters myRSAParameters = RSA.ExportParameters(false);
myRSAParameters.Modulus = pub;
myRSAParameters.Exponent = ByteConverter.GetBytes("65537");
myRSAParameters.D = prv;
encryptedData = RSAEncrypt(dataToEncrypt, myRSAParameters, false);
decryptedData = RSADecrypt(encryptedData, myRSAParameters, false);
decrptedStr = ByteConverter.GetString(decryptedData);
}
}
static public byte[] RSAEncrypt(byte[] DataToEncrypt, RSAParameters RSAKeyInfo, bool DoOAEPPadding) {
try {
byte[] encryptedData;
using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider()) {
RSA.ImportParameters(RSAKeyInfo);
encryptedData = RSA.Encrypt(DataToEncrypt, DoOAEPPadding);
}
return encryptedData;
} catch (CryptographicException e) {
Console.WriteLine(e.Message);
return null;
}
}
static public byte[] RSADecrypt(byte[] DataToDecrypt, RSAParameters RSAKeyInfo, bool DoOAEPPadding) {
try {
byte[] decryptedData;
using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider()) {
RSA.ImportParameters(RSAKeyInfo);
decryptedData = RSA.Decrypt(DataToDecrypt, DoOAEPPadding);
}
return decryptedData;
} catch (CryptographicException e) {
Console.WriteLine(e.ToString());
return null;
}
}
}
}
在行 encryptedData = RSAEncrypt(dataToEncrypt, myRSAParameters, false);
数据加密但在下一行我有这个错误:
System.Security.Cryptography.CryptographicException: PKCS1 decoding error.
at System.Security.Cryptography.RSAPKCS1KeyExchangeDeformatter.DecryptKeyExchange (System.Byte[] rgbIn) [0x00000] in <filename unknown>:0
at System.Security.Cryptography.RSACryptoServiceProvider.Decrypt (System.Byte[] rgb, Boolean fOAEP) [0x00000] in <filename unknown>:0
我想我没有正确填写 myRSAParameters
属性,但我不知道如何填写!
最佳答案
在 .NET 中,如果您指定 RSAParameters.D,您还必须为 P、Q、DP、DQ 和 InverseQ 指定(正确的)值。
虽然从技术上讲,模数、指数和 D 都是执行 RSA 所必需的,但实际上很少有实现使用 D,因为执行 RSA via the Chinese Remainder Theorem 效率更高。 .
例如,虽然 OpenSSL 将退回到仅使用 D; .NET 不会。
关于c# - 如何将私钥导入 c# RSAParameters 对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33047476/
这个问题在这里已经有了答案: Correctly create RSACryptoServiceProvider from public key (3 个答案) 关闭 5 年前。 我有用 Base6
RSAParameters对象不支持私钥数据的序列化。如何完全序列化和反序列化私钥? 最佳答案 以下代码可用于序列化和反序列化 RSAParameters对象,使用您自己选择的序列化程序。 using
我想使用我自己提供的非对称 key 在 .Net 4.5 中生成 JWT token ,但我遇到了 System.IdentityModel.Tokens.Jwt 版本 4.0.3 的一些问题。 我最
网上看了一些教程,生成了公钥和私钥,但是如何设置才能在C#中使用呢?这是我所拥有的: string publicKey = "..."; string privateK
我想在c#中用rsa加密和解密数据。我写了这段代码,它可以很好地加密,但我在解密时遇到了问题。我的问题是什么?! 这是我的代码: using System; using System.Security
我想根据 RSACryptoServiceProvider 创建的 key 创建一个 pfx 文件。我试过: certificate.PrivateKey = rsa as AsymmetricAl
我在我的项目中使用以下代码进行加密,一切正常。 RSACryptoServiceProvider x_alg = new RSACryptoServiceProvider( ); // export
P 和 Q 的值与 .Net RSAParameters 的模数值不匹配。根据 RSA 算法和 MSDN 文档,它应该是:P * Q = Modulus 我生成了一个 512 位 RSA key 对并
你好,我有一个在 .net 中生成的 RSA 的私钥和公钥 采用这种格式 string privateKey = "" + "...kCFhsjB4x
我盯着这个看了很长一段时间,感谢 MSDN documentation我真的不知道发生了什么。基本上,我将光盘中的 PFX 文件加载到 X509Certificate2 中,并尝试使用公钥加密字符串并
我是一名优秀的程序员,十分优秀!