无法使用私钥对文本块进行签名

时间:2013-06-04 10:15:30

标签: public-key-encryption signing private-key sha256 public-key

我正在尝试创建一堆剪贴板文本的数字签名。我是:

  1. 创建纯文本的SHA-256哈希。
  2. 使用我的私钥加密此哈希。
  3. 尝试使用我的PUBLIC密钥解密此内容。
  4. 我这样做是因为我理解用我的私钥进行签名的任何内容都可以用我的PUBLIC解密 - 比如用于验证?这是错的吗?

    我正在用这些方法加密哈希:

                    public static string EncryptText(string text, int keySize, string publicKey)
                {
                    var encrypted = Encrypt(Encoding.UTF8.GetBytes(text), keySize, publicKey);
                    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);
                    }
                }
    

    但是将PRIVATE KEY传递给我而不是PUBLIC KEY

    然后验证签名,我正在使用:

                    public static string DecryptText(string privateKey, int keySize, string text)
                {
                    var decrypted = Decrypt(Convert.FromBase64String(text), keySize, privateKey);
                    return Encoding.UTF8.GetString(decrypted);
                }
    
                public static byte[] Decrypt(byte[] data, int keySize, string publicAndPrivateKeyXml)
                {
                    if (data == null || data.Length == 0) throw new ArgumentException("Data are empty", "data");
                    if (!IsKeySizeValid(keySize)) throw new ArgumentException("Key size is not valid", "keySize");
                    if (String.IsNullOrEmpty(publicAndPrivateKeyXml)) throw new ArgumentException("Key is null or empty", "publicAndPrivateKeyXml");
    
                    using (var provider = new RSACryptoServiceProvider(keySize))
                    {
                        provider.FromXmlString(publicAndPrivateKeyXml);
                        return provider.Decrypt(data, OptimalAsymmetricEncryptionPadding);
                    }
                }
    

    但是传递了PUBLIC KEY而不是PRIVATE KEY。此时,我收到错误“密钥不存在”。

    我认为是这种情况,因为PRIVATE KEY包含PUBLIC KEY的相关密钥信息,因此它可以单向解码。

    如何以这种方式签署一个文本块,允许我用它分发签名,任何知道我PUBLIC KEY的人都可以解密?

1 个答案:

答案 0 :(得分:0)

经过多次拖网,我找到了这个页面: http://juzzbott.com.au/blog/signing-and-verifying-data-within-csharp