C#字符串加密解密方法实例

C#字符串加密解密方法实例

背景

在对程序进行开发时,有时候需要对一些敏感数据进行加密,以保证数据安全。在C#中,有许多方法来实现字符串的加密解密。

对称加密

对称加密是最常用的一种加密方式,加密和解密使用相同的密钥。常见的对称加密算法有DES、AES和IDEA等。

加密方法示例

下面是一段使用AES加密算法对明文进行加密的示例代码:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

public static string AESEncrypt(string plainText, byte[] key, byte[] iv)
{
    using (Aes aes = Aes.Create())
    {
        aes.Key = key;
        aes.IV = iv;

        ICryptoTransform encryptor = aes.CreateEncryptor(aes.Key, aes.IV);

        using (MemoryStream ms = new MemoryStream())
        {
            using (CryptoStream cs = new CryptoStream(ms, encryptor, CryptoStreamMode.Write))
            {
                using (StreamWriter sw = new StreamWriter(cs))
                {
                    sw.Write(plainText);
                }
            }
            byte[] encrypted = ms.ToArray();
            return Convert.ToBase64String(encrypted);
        }
    }
}

解密方法示例

下面是一段使用AES解密算法对密文进行解密的示例代码:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

public static string AESDecrypt(string encryptedText, byte[] key, byte[] iv)
{
    using (Aes aes = Aes.Create())
    {
        aes.Key = key;
        aes.IV = iv;

        ICryptoTransform decryptor = aes.CreateDecryptor(aes.Key, aes.IV);

        using (MemoryStream ms = new MemoryStream(Convert.FromBase64String(encryptedText)))
        {
            using (CryptoStream cs = new CryptoStream(ms, decryptor, CryptoStreamMode.Read))
            {
                using (StreamReader sr = new StreamReader(cs))
                {
                    return sr.ReadToEnd();
                }
            }
        }
    }
}

非对称加密

非对称加密是一种最常用的公钥加密方式,也称为公钥密码学,加密和解密使用不同的密钥。常见的非对称加密算法有RSA、DSA和ECC等。

加密方法示例

下面是一段使用RSA算法对明文进行加密的示例代码:

using System;
using System.Security.Cryptography;
using System.Text;

public static string RSAEncrypt(string plainText, string publicKeyXml)
{
    using (RSACryptoServiceProvider provider = new RSACryptoServiceProvider())
    {
        provider.FromXmlString(publicKeyXml);

        byte[] plainBytes = Encoding.UTF8.GetBytes(plainText);
        byte[] encryptedBytes = provider.Encrypt(plainBytes, false);

        return Convert.ToBase64String(encryptedBytes);
    }
}

解密方法示例

下面是一段使用RSA算法对密文进行解密的示例代码:

using System;
using System.Security.Cryptography;
using System.Text;

public static string RSADecrypt(string encryptedText, string privateKeyXml)
{
    using (RSACryptoServiceProvider provider = new RSACryptoServiceProvider())
    {
        provider.FromXmlString(privateKeyXml);

        byte[] encryptedBytes = Convert.FromBase64String(encryptedText);
        byte[] decryptedBytes = provider.Decrypt(encryptedBytes, false);

        return Encoding.UTF8.GetString(decryptedBytes);
    }
}

总结

以上就是C#字符串加密解密的两种常见方式,具体使用哪种方式根据需求和实际情况来决定。在实际开发时,还需要注意保护密钥和加密算法的安全性,以免被攻击者利用。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C#字符串加密解密方法实例 - Python技术站

(0)
上一篇 2023年6月8日
下一篇 2023年6月8日

相关文章

  • 解决import包时报 Java 程序包不存在的问题

    在Java开发中,我们经常需要引入其他包中的类或接口。但有时候在import包时会出现Java程序包不存在的问题。以下是解决import包时报Java程序包不存在的问题的完整攻略。 环境准备 在解决import包时报Java程序包不存在的问题前,需要确保以下环境已经准备好: JDK已经安装并配置好了环境变量。 项目中已经添加了需要引入的包的依赖。 解决imp…

    C# 2023年5月15日
    00
  • C# 泛型的约束

    下面是详细讲解 “C# 泛型的约束” 的完整攻略,包括概念、使用方法和示例说明等: 概念 在 C# 中,泛型是一种让类或方法可以支持多种数据类型的技术。泛型的优点是能够让程序更加灵活、可扩展,同时也避免了大量的重复代码。而泛型的约束则是用来限制泛型类型参数的类型或属性的限制条件,以确保泛型类型参数符合特定需求,比如实现某种接口、具有某种属性等。 使用方法 泛…

    C# 2023年5月31日
    00
  • C#生成指定范围内的不重复随机数

    下面是” C#生成指定范围内的不重复随机数 “的攻略。 1. 使用 C# 的 Random 类生成随机数 System.Random 是 C# 中封装了随机数生成器的类,可以用来生成伪随机数。Random 的默认构造函数可以产生种子数,可以在每次生成随机数时用来确定这个随机数系列的起始位置,从而产生不同的随机数序列。 2. 生成指定范围内的随机数 生成指定范…

    C# 2023年6月7日
    00
  • C#检查Windows是否安装了某个服务的方法

    我将为您详细讲解“C#检查Windows是否安装了某个服务的方法”的完整攻略。 方法 要检查Windows是否安装了某个服务,我们可以使用C#语言提供的System.ServiceProcess命名空间中的ServiceController类。 该类允许我们检查、启动、停止、暂停或恢复Windows服务。 以下是使用ServiceController类检查W…

    C# 2023年6月7日
    00
  • Redis缓存,泛型集合与json字符串的相互转换实例

    Redis缓存、泛型集合与json字符串的相互转换 在使用 Redis 做缓存时,经常需要将对象转为 json 格式,以便存储到 Redis 中,或者从 Redis 中读取出来时,将 json 转为对象。在 Java 中,可以使用泛型集合来方便的表示对象集合,再使用相关库来实现对象和 json 字符串之间的相互转化。 下面介绍一个 Redis 缓存、泛型集合…

    C# 2023年5月31日
    00
  • ASP.NET MVC验证码功能实现代码

    当用户填写表单时,防止自动化脚本恶意提交表单的一种有效方式是通过验证码来验证用户的身份。下面是一个ASP.NET MVC验证码功能实现的完整攻略。 步骤一:在视图中添加验证码 添加一个表单或者用户输入数据的其他元素,然后在元素下方放置一个图片框来显示验证码的图片。图片框应该包含一个用于输入验证码的文本输入框,和一个刷新验证码的按钮。下面是一个示例: <…

    C# 2023年5月31日
    00
  • C#关键字async/await用法

    下面是”C#关键字async/await用法”的完整攻略。 标题 C#关键字async/await用法 介绍 async/await是C# 5.0版本中新增的关键字,用于简化异步编程的过程。当我们需要在.NET应用程序中执行耗时操作时,通常会遇到线程阻塞、死锁、竞争和上下文问题等问题。使用async/await可以很好地解决这些问题,使得代码更易于编写和理解…

    C# 2023年6月6日
    00
  • C# DateTime.AddSeconds()方法: 将指定的秒数加到指定的日期上

    DateTime.AddSeconds()方法简介 在 C# 中,DateTime 类型的实例代表了日期和时间值。AddSeconds() 是 DateTime 类型提供的一个方法,它的作用是向 DateTime 对象添加指定的秒数。它会返回一个新的 DateTime 对象,表示当前对象加上指定秒数后的日期和时间。 方法定义如下: public DateTi…

    C# 2023年4月19日
    00
合作推广
合作推广
分享本页
返回顶部