C# SHA256WithRSA签名、验签 .net4.0

public static string Sign(string contentForSign, string privateKey)
        {
            //转换成适用于.Net的秘钥
            var netKey = RSAPrivateKeyJava2DotNet(privateKey);
            var rsa = new RSACryptoServiceProvider();
            rsa.FromXmlString(netKey);
            //创建一个空对象
            var rsaClear = new RSACryptoServiceProvider();
            var paras = rsa.ExportParameters(true);
            rsaClear.ImportParameters(paras);
            //签名返回
            using (var sha256 = new SHA256CryptoServiceProvider())
            {
                var signData = rsa.SignData(Encoding.UTF8.GetBytes(contentForSign), sha256);
                //return BytesToHex(signData);
                return Convert.ToBase64String(signData);
            }
        }
        public static string RSAPrivateKeyJava2DotNet(string privateKey)
        {
            RsaPrivateCrtKeyParameters privateKeyParam = (RsaPrivateCrtKeyParameters)PrivateKeyFactory.CreateKey(Convert.FromBase64String(privateKey));

            return string.Format("<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent><P>{2}</P><Q>{3}</Q><DP>{4}</DP><DQ>{5}</DQ><InverseQ>{6}</InverseQ><D>{7}</D></RSAKeyValue>",
                Convert.ToBase64String(privateKeyParam.Modulus.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.PublicExponent.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.P.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.Q.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.DP.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.DQ.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.QInv.ToByteArrayUnsigned()),
                Convert.ToBase64String(privateKeyParam.Exponent.ToByteArrayUnsigned()));
        }

 public static string RSAPublicKeyJava2DotNet(string publikKey)
        {     
            RsaKeyParameters publicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(Convert.FromBase64String(publikKey));
            return string.Format("<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent></RSAKeyValue>",
                Convert.ToBase64String(publicKeyParam.Modulus.ToByteArrayUnsigned()),
                Convert.ToBase64String(publicKeyParam.Exponent.ToByteArrayUnsigned()));
        }

/// <summary>        /// RSA签名验证
        /// <param name="sEncryptSource">密文</param>
        /// <param name="sCompareString">需要比较的明文字符串</param>
        /// <param name="sPublicKey">公匙</param>
        /// <returns>是否相同</returns>
        public static bool VerifySignature(string sEncryptSource, string sCompareString, string sPublicKey)
        {
            try
            {
                using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())
                {
                    rsa.FromXmlString(RSAPublicKeyJava2DotNet(sPublicKey));
                    RSAPKCS1SignatureDeformatter df = new RSAPKCS1SignatureDeformatter(rsa);
                    df.SetHashAlgorithm("SHA256");
                    byte[] signature = Convert.FromBase64String(sEncryptSource);
                    SHA256Managed sha2 = new SHA256Managed();
                    // byte[] compareByte = sha2.ComputeHash(System.Text.Encoding.Default.GetBytes(sCompareString));
                    string strBase64 = "";
                    byte[] b = System.Text.Encoding.Default.GetBytes(sCompareString);
                    //转成 Base64 形式的 System.String  
                    strBase64 = Convert.ToBase64String(b);
                    byte[] compareByte = sha2.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strBase64));
                    return df.VerifySignature(compareByte, signature);
                }
            }
            catch (Exception)
            {
                return false;
            }
        }
 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中使用SHA256withRSA进行的过程如下: 首先,你需要获取公钥和待证的字符串。然后,你可以使用RSACryptoServiceProvider类的FromXmlString方法将公钥转换为适用于.NET的格式\[2\]。接下来,你需要将待证的字符串转换为字节数组,并使用SHA256CryptoServiceProvider类计算其哈希值\[2\]。 然后,你可以使用RSAPKCS1SignatureDeformatter类进行。你需要创建一个RSAPKCS1SignatureDeformatter对象,并设置其HashAlgorithm属性为"SHA256"\[2\]。然后,你需要将签名数据转换为字节数组,并使用RSAPKCS1SignatureDeformatter对象的VerifySignature方法进行。该方法将返回一个布尔值,表示是否成功\[2\]。 下面是一个示例代码: ```csharp public static bool VerifySignature(string encryptSource, string compareString, string publicKey) { using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider()) { rsa.FromXmlString(publicKey); byte\[\] signature = Convert.FromBase64String(encryptSource); SHA256Managed sha256 = new SHA256Managed(); RSAPKCS1SignatureDeformatter deformatter = new RSAPKCS1SignatureDeformatter(rsa); deformatter.SetHashAlgorithm("SHA256"); byte\[\] compareByte = sha256.ComputeHash(Encoding.UTF8.GetBytes(compareString)); return deformatter.VerifySignature(compareByte, signature); } } ``` 你可以将待证的签名数据、待证的字符串和公钥作为参数传递给VerifySignature方法。该方法将返回一个布尔值,表示是否成功\[2\]。 希望这个回答对你有帮助! #### 引用[.reference_title] - *1* *2* [C#使用Java的秘钥对进行SHA256withRSA签名](https://blog.csdn.net/bcacba/article/details/120325938)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [C# SHA256WithRSA签名 .net4.0](https://blog.csdn.net/qq_32002821/article/details/109801984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值