Web开发:AES加密解密的demo

本文介绍了如何使用C#中的AesEncryptionDemo类进行AES加密和解密操作,涉及密钥和初始向量的生成、加密算法的应用以及明文到密文的转换过程。
摘要由CSDN通过智能技术生成

可直接在控制台程序运行:

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

public class AesEncryptionDemo
{
    public static byte[] Encrypt(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 memoryStream = new MemoryStream())
            {
                using (CryptoStream cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write))
                {
                    byte[] plainBytes = Encoding.UTF8.GetBytes(plainText);
                    cryptoStream.Write(plainBytes, 0, plainBytes.Length);
                    cryptoStream.FlushFinalBlock();
                    return memoryStream.ToArray();
                }
            }
        }
    }

    public static string Decrypt(byte[] cipherText, 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 memoryStream = new MemoryStream(cipherText))
            {
                using (CryptoStream cryptoStream = new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read))
                {
                    byte[] plainBytes = new byte[cipherText.Length];
                    int decryptedByteCount = cryptoStream.Read(plainBytes, 0, plainBytes.Length);
                    return Encoding.UTF8.GetString(plainBytes, 0, decryptedByteCount);
                }
            }
        }
    }

    public static void Main()
    {
        string plainText = "123456";
        byte[] key = new byte[32]; // AES-256 使用 32 字节的密钥
        byte[] iv = new byte[16]; // AES 使用 16 字节的初始向量

        // 生成随机的密钥和初始向量key iv
        using (RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider())
        {
            rng.GetBytes(key);
            rng.GetBytes(iv);
        }

        string ivHex = BitConverter.ToString(iv).Replace("-", "").ToLower();//将密钥和初始向量转化为字符串存入数据库
        string keyHex = BitConverter.ToString(key).Replace("-", "").ToLower();

        byte[] ivHexs = Enumerable.Range(0, ivHex.Length)//将数据库密钥和初始向量字符串取出并转化为字节形式
                          .Where(x => x % 2 == 0)
                          .Select(x => Convert.ToByte(ivHex.Substring(x, 2), 16))
                          .ToArray();
        byte[] keyHexs = Enumerable.Range(0, keyHex.Length)
                          .Where(x => x % 2 == 0)
                          .Select(x => Convert.ToByte(keyHex.Substring(x, 2), 16))
                          .ToArray();

        byte[] cipherText = Encrypt(plainText, key, iv);//明文=》密文,其中key和iv为随机生成的密钥和初始向量(字节)
        string decryptedText = Decrypt(cipherText, key, iv);//密文=》明文,其中key和iv为随机生成的密钥和初始向量(字节)

        Console.WriteLine("Plain Text: " + plainText);// 明文
        Console.WriteLine("Cipher Text: " + Convert.ToBase64String(cipherText));//密文
        Console.WriteLine("Decrypted Text: " + decryptedText);//解密后的明文
    }
}

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: RSA(Rivest-Shamir-Adleman)和AES(Advanced Encryption Standard)是两种流行的加密算法。RSA是一种非对称加密算法,可以用于加密和数字签名。AES是一种对称加密算法,用于加密和解密数据。 如果想要了解RSA和AES加密原理和实现方式,可以下载相应的加密demo进行学习和实践。网上有很多网站提供这些demo的下载,比如GitHub和其他软件开发社区。 对于RSA加密,可以下载Java, Python和C++等不同语言的demo进行学习。这些demo通常会包含RSA密钥的生成、数据加密和解密等操作,通过实践可以更好地理解RSA算法在实际应用中的工作原理。 同样地,对于AES加密,也可以下载不同语言的demo来学习。在实践中,可以使用不同的AES加密模式,如ECB、CBC、CFB和OFB,掌握它们的优缺点以及在不同场景下的应用。 总之,通过下载和实践RSA和AES加密demo,可以更好地了解这两种加密算法的原理和应用,提高对数据加密和安全保护的认识和能力。 ### 回答2: RSA和AES都是常用的加密算法,RSA用于加密和解密数据,AES用于对称加密。这两种加密算法都有其独特的优点和缺点,用于不同的场景。 如果你想学习RSA和AES加密和解密原理,可以下载相关的加密示例程序进行学习。这些示例程序通常包括两个部分:加密和解密。 加密部分通常需要输入明文和密钥,通过RSA或AES算法对明文进行加密加密后的结果可作为密文传输或保存。 解密部分通常需要输入密文和密钥,通过RSA或AES算法对密文进行解密,得到明文。 在下载RSA和AES加密示例程序之前,需要先了解一些基本概念和原理。需要了解密钥的概念,密钥的长度和安全性等问题。此外,针对不同的加密算法和加密场景,还需要了解不同的加密策略和实现方法。 总之,下载RSA和AES加密示例程序是为了更好地学习和深入理解这两种常用的加密算法。通过学习加密思想和方法,我们可以更好地保护数据安全和隐私。 ### 回答3: RSA和AES是两种常见的加密算法,分别用于数据传输加密和数据存储加密。为了方便开发人员理解这两种算法的使用,许多网站或书籍上都提供了RSA和AES加密DEMO下载。 对于初学者来说,下载和运行这些DEMO可以帮助他们快速了解RSA和AES加密方式,并通过实际的操作加深对这两种算法的理解。在下载DEMO时需要注意一些问题:首先要选择可信的下载渠道,确保下载到的文件不含有恶意代码。其次要选择适合自己的编程语言版本,以便更好地理解和运用。 对于开发人员来说,下载和使用RSA和AES加密DEMO是非常有益的。例如,在使用RSA加密过程中,可以通过调整不同的参数来控制公钥和私钥的长度,从而实现更高的加密强度。在使用AES加密过程中,可以探究不同的加密模式(如ECB,CBC等),以及不同的加密密钥长度对加密强度的影响。 总之,下载和使用RSA和AES加密DEMO是一种非常好的学习和实践加密算法的方法。希望广大开发者能够充分掌握这两种算法的原理和使用方法,增强数据安全意识,提高数据加密能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值