5

我是 RSA 加密的新手,我一直在尝试了解它是如何使用 .Net 的System.Security.Cryptography

    public String Encryption(Byte[] Input, RSAParameters PublicKey)
    {
        RSAC = new RSACryptoServiceProvider();
        RSAC.ImportParameters(PublicKey);
        Byte[] Encrypt = RSAC.Encrypt(Input, false);
        return Convert.ToBase64String(Encrypt);
    }

使用上面的代码,每当我重新启动应用程序时,我都会为相同的输入获得不同的加密字符串。我想知道这是否是正常行为,如果不是,如何预防。

例如,程序为输入“Hello”返回以下字符串:

NopDAF5FRu....

当我重新启动应用程序时,相同输入的输出将是:

pPPu8x6....

但是,当我为我的 RSA 加密类创建新对象时,所有对象都返回相同的输出。

4

1 回答 1

6

这是完全正常和好的。被加密的数据被放在一个用随机值填充的块内。然后用公钥加密。

有关更多详细信息,请参阅此SO Q&A

于 2013-11-16T15:45:16.123 回答