net core 配置文件加密(RSA加密)

在配置文件中,数据库连接字符串,缓存链接字符串等敏感信息,需要配置成加密形式。今天记录一下工作经验

我使用的是RSA加密
先安装依赖包

首先生成公钥私钥

公钥与私钥是匹配的,公钥加密过后使用对应的私钥进行解密

 /// <summary>
        /// 生成PEM格式的公钥和密钥
        /// </summary>
        /// <param name="strength">长度</param>
        /// <returns>Item1:公钥;Item2:私钥;</returns>
        public static (string, string) CreateKeyPair(int strength = 1024)
        {
            RsaKeyPairGenerator r = new RsaKeyPairGenerator();
            r.Init(new KeyGenerationParameters(new SecureRandom(), strength));
            AsymmetricCipherKeyPair keys = r.GenerateKeyPair();
            TextWriter privateTextWriter = new StringWriter();
            PemWriter privatePemWriter = new PemWriter(privateTextWriter);
            privatePemWriter.WriteObject(keys.Private);
            privatePemWriter.Writer.Flush();
            TextWriter publicTextWriter = new StringWriter();
            PemWriter publicPemWriter = new PemWriter(publicTextWriter);
            publicPemWriter.WriteObject(keys.Public);
            publicPemWriter.Writer.Flush();
            return (publicTextWriter.ToString(), privateTextWriter.ToString());
        }

RSA加密算法

   /// <summary>
                /// RSA加密
                /// </summary>
                /// <param name="publicKey">公钥</param>
                /// <param name="decryptstring">待加密的字符串(Base64)</param>
                /// <returns>加密后的字符串</returns>
               public static string Crypt(string publicKey, string decryptstring)
               {
                    decryptstring = Convert.ToBase64String(System.Text.Encoding.Default.GetBytes(decryptstring));
                  using (TextReader reader = new StringReader(publicKey))
                 {
                     dynamic key = new PemReader(reader).ReadObject();
                     var rsaDecrypt = new Pkcs1Encoding(new RsaEngine());
                     if (key is AsymmetricKeyParameter)
                     {
                        key = (AsymmetricKeyParameter)key;
                     }
                     else if (key is AsymmetricCipherKeyPair)
                     {
                        key = ((AsymmetricCipherKeyPair)key).Private;
                     }
                     rsaDecrypt.Init(true, key); //这里加密是true;解密是false

                     byte[] entData = Convert.FromBase64String(decryptstring);
                     entData = rsaDecrypt.ProcessBlock(entData, 0, entData.Length);
                     return Convert.ToBase64String(entData);
                 }
              }

RSA解密算法

 /// <summary>
        /// RSA解密,解密失败返回原字符串
        /// </summary>
        /// <param name="privateKey">私钥</param>
        /// <param name="decryptstring">待解密的字符串(Base64)</param>
        /// <returns>解密后的字符串</returns>
        public static string Decrypt(string privateKey, string decryptstring)
        {
            try
            {
                using (TextReader reader = new StringReader(privateKey))
                {
                    dynamic key = new PemReader(reader).ReadObject();
                    var rsaDecrypt = new Pkcs1Encoding(new RsaEngine());
                    if (key is AsymmetricKeyParameter)
                    {
                        key = (AsymmetricKeyParameter)key;
                    }
                    else if (key is AsymmetricCipherKeyPair)
                    {
                        key = ((AsymmetricCipherKeyPair)key).Private;
                    }
                    rsaDecrypt.Init(false, key); //这里加密是true;解密是false

                    byte[] entData = Convert.FromBase64String(decryptstring);
                    entData = rsaDecrypt.ProcessBlock(entData, 0, entData.Length);
                    return Encoding.UTF8.GetString(entData);
                } 
            }
            catch (Exception e)
            {
                return decryptstring;
            }
        }

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Hutool进行RSA加密和解密的例子: ```java import cn.hutool.crypto.asymmetric.KeyType; import cn.hutool.crypto.asymmetric.RSA; public class RSATest { public static void main(String[] args) { // 生成RSA密钥对 RSA rsa = new RSA(); String publicKey = rsa.getPublicKeyBase64(); String privateKey = rsa.getPrivateKeyBase64(); System.out.println("公钥:" + publicKey); System.out.println("私钥:" + privateKey); // 加密 String data = "Hello, World!"; byte[] encrypt = rsa.encrypt(data.getBytes(), KeyType.PublicKey); String encryptStr = cn.hutool.core.codec.Base64.encode(encrypt); System.out.println("加密后的数据:" + encryptStr); // 解密 byte[] decrypt = rsa.decrypt(cn.hutool.core.codec.Base64.decode(encryptStr), KeyType.PrivateKey); String decryptStr = new String(decrypt); System.out.println("解密后的数据:" + decryptStr); } } ``` 在上面的例子中,我们首先使用`RSA`类生成RSA密钥对,然后使用公钥对数据进行加密,使用私钥对加密后的数据进行解密。在加密和解密时,我们需要指定密钥类型(公钥或私钥)。最后,我们将加密和解密后的数据进行输出验证。注意,我们在输出加密后的数据时,使用了`cn.hutool.core.codec.Base64.encode`方法将加密后的字节数组转换为Base64字符串,以便更方便地输出和传输。同样,在解密时,我们使用了`cn.hutool.core.codec.Base64.decode`方法将Base64字符串转换为字节数组。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值