.net 使用RSA生成密钥对,生成待签名的字符串用SHA256签名、验签(纯.net版)

using System;
using System.Collections.Generic;
using System.Security.Cryptography;
using System.Text;
using System.Xml;

/// <summary>
        /// 将参数组成代签名的字符串
        /// </summary>
        /// <param name="parameters"></param>
        /// <returns></returns>
        public static string GetSignContent(IDictionary<string, string> parameters)
        {
            // 第一步:把字典按Key的字母顺序排序
            IDictionary<string, string> sortedParams = new SortedDictionary<string, string>(parameters);
            IEnumerator<KeyValuePair<string, string>> dem = sortedParams.GetEnumerator();

            // 第二步:把所有参数名和参数值串在一起
            StringBuilder query = new StringBuilder("");
            while (dem.MoveNext())
            {
                string key = dem.Current.Key;
                string value = dem.Current.Value;
                if (!string.IsNullOrEmpty(key) && !string.IsNullOrEmpty(value))
                {
                    query.Append(key).Append("=").Append(value).Append("&");
                }
            }
            //第三步:判断参数是否有值
            string content = null;
            if (query != null)
            {
                content = query.ToString().Substring(0, query.Length - 1);
            }
            return content;
        }
        /// <summary>
        /// C#生成私钥加密
        /// </summary>
        /// <param name="data"></param>
        /// <param name="privatekey"></param>
        /// <returns></returns>
        public static string RSADecrypt(string data, string privatekey)
        {
            var rsa = new RSACryptoServiceProvider();
            rsa.FromXmlString(privatekey);

            var rsaClear = new RSACryptoServiceProvider();
            var paras = rsa.ExportParameters(true);
            rsaClear.ImportParameters(paras); //签名返回
            using (var sha256 = new SHA256CryptoServiceProvider())
            {
                var signData = rsa.SignData(Encoding.UTF8.GetBytes(data), sha256);
                return Convert.ToBase64String(signData);
            }
        }
        /// RSA签名验证
        /// </summary> 
        /// <param name="encryptSource">签名</param>
        /// <param name="c">验证的字符串</param>
        /// <param name="publicKey">公钥</param>
        /// <returns>是否相同,true验证成功,false验证失败。</returns>
        public static bool Signature(string encryptSource, string compareString, string publicKey)
        {
            try
            {
                using (RSACryptoServiceProvider rsa = FromXmlString(publicKey))//
                //using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())
                {
                    //rsa.FromXmlString(publicKey);.net Core 在3.0以上的使用注释代码 无需重写
                    byte[] signature = Convert.FromBase64String(encryptSource);
                    SHA256Managed sha256 = new SHA256Managed();
                    RSAPKCS1SignatureDeformatter df = new RSAPKCS1SignatureDeformatter(rsa);
                    df.SetHashAlgorithm("SHA256");
                    byte[] compareByte = sha256.ComputeHash(Encoding.UTF8.GetBytes(compareString));

                    return df.VerifySignature(compareByte, signature);
                }
            }
            catch (Exception)
            {
                return false;
            }
        }
        /// <summary>
        /// 重写FromXmlString方法
        /// </summary>
        /// <param name="xmlString"></param>
        /// <returns></returns>
        public static RSACryptoServiceProvider FromXmlString(string xmlString)
        {
            var rsa = new RSACryptoServiceProvider();
            RSAParameters parameters = new RSAParameters();
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.LoadXml(xmlString);
            if (xmlDoc.DocumentElement.Name.Equals("RSAKeyValue"))
            {
                foreach (XmlNode node in xmlDoc.DocumentElement.ChildNodes)
                {
                    switch (node.Name)
                    {
                        case "Modulus": parameters.Modulus = Convert.FromBase64String(node.InnerText); break;
                        case "Exponent": parameters.Exponent = Convert.FromBase64String(node.InnerText); break;
                        case "P": parameters.P = Convert.FromBase64String(node.InnerText); break;
                        case "Q": parameters.Q = Convert.FromBase64String(node.InnerText); break;
                        case "DP": parameters.DP = Convert.FromBase64String(node.InnerText); break;
                        case "DQ": parameters.DQ = Convert.FromBase64String(node.InnerText); break;
                        case "InverseQ": parameters.InverseQ = Convert.FromBase64String(node.InnerText); break;
                        case "D": parameters.D = Convert.FromBase64String(node.InnerText); break;
                    }
                }
            }
            else
            {
                throw new Exception("Invalid XML RSA key.");
            }

            rsa.ImportParameters(parameters);
            return rsa;
        }
        public static void Main(string[] args)
        {
            Console.WriteLine("你喜欢什么动漫?");
            string like = Console.ReadLine();
            Console.WriteLine("其中喜欢角色的名字为什么?");
            string name = Console.ReadLine();
            Console.WriteLine("你喜欢的动漫角色穿黑丝吗?");
            string blackSilk = Console.ReadLine();
            var content = new Dictionary<string, string>()
            {
                {"like",$"{like}"},
                {"name",$"{name}"},
               {"blackSilk",$"{blackSilk}"}
            };
            //生成待签名字符串
            string Data = GetSignContent(content);
            //生成秘钥对
            RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();

            string str_Private_Key = RSAalg.ToXmlString(true);
            string str_Public_Key = RSAalg.ToXmlString(false);
            //生成签名
            string netSings = RSADecrypt(Data, str_Private_Key);
            //验签
            bool attes = Signature(netSings, Data, str_Public_Key);
            Console.WriteLine(attes);

            Console.WriteLine("Hello World!", attes);
        }

Java版的使用Java的秘钥对进行SHA256withRSA签名验签_bcacba的博客-CSDN博客

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 C# 语言使用 PEM 的本地文件 RSA信息,以及 SHA256 的签名代码: 加: ``` using System; using System.IO; using System.Security.Cryptography; using System.Text; public static string Encrypt(string publicKeyPath, string plainText) { var rsa = new RSACryptoServiceProvider(); var publicKey = File.ReadAllText(publicKeyPath); rsa.FromXmlString(publicKey); var plainBytes = Encoding.UTF8.GetBytes(plainText); var encryptedBytes = rsa.Encrypt(plainBytes, false); return Convert.ToBase64String(encryptedBytes); } ``` 解: ``` using System; using System.IO; using System.Security.Cryptography; using System.Text; public static string Decrypt(string privateKeyPath, string encryptedText) { var rsa = new RSACryptoServiceProvider(); var privateKey = File.ReadAllText(privateKeyPath); rsa.FromXmlString(privateKey); var encryptedBytes = Convert.FromBase64String(encryptedText); var plainBytes = rsa.Decrypt(encryptedBytes, false); return Encoding.UTF8.GetString(plainBytes); } ``` 签名: ``` using System; using System.IO; using System.Security.Cryptography; using System.Text; public static string Sign(string privateKeyPath, string plainText) { var rsa = new RSACryptoServiceProvider(); var privateKey = File.ReadAllText(privateKeyPath); rsa.FromXmlString(privateKey); var plainBytes = Encoding.UTF8.GetBytes(plainText); var signatureBytes = rsa.SignData(plainBytes, new SHA256CryptoServiceProvider()); return Convert.ToBase64String(signatureBytes); } ``` : ``` using System; using System.IO; using System.Security.Cryptography; using System.Text; public static bool Verify(string publicKeyPath, string plainText, string signatureText) { var rsa = new RSACryptoServiceProvider(); var publicKey = File.ReadAllText(publicKeyPath); rsa.FromXmlString(publicKey); var plainBytes = Encoding.UTF8.GetBytes(plainText); var signatureBytes = Convert.FromBase64String(signatureText); return rsa.VerifyData(plainBytes, new SHA256CryptoServiceProvider(), signatureBytes); } ``` 注意:以上代码仅供参考,实际使用时需要根据具体情况进行修改和调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值