a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

C#實現對AES加密和解密的方法

2020-01-24 03:25:54
字體:
來源:轉載
供稿:網友

AES簡介

AES(The Advanced Encryption Standard)是美國國家標準與技術研究所用于加密電子數據的規范。它被預期能成為人們公認的加密包括金融、電信和政府數字信息的方法。

AES 是一個新的可以用于保護電子數據的加密算法。明確地說,AES 是一個迭代的、對稱密鑰分組的密碼,它可以使用128、192 和 256 位密鑰,并且用 128 位(16字節)分組加密和解密數據。與公共密鑰密碼使用密鑰對不同,對稱密鑰密碼使用相同的密鑰加密和解密數據。通過分組密碼返回的加密數據 的位數與輸入數據相同。以下是我經過整理的代碼,希望對大家有所幫助:

復制代碼 代碼如下:

/// <summary>
/// ASE加解密
/// </summary>
public class AESHelper
{
    /// <summary>
    /// 獲取密鑰
    /// </summary>
    private static string Key
    {
        get
        {
            return "abcdef1234567890";    ////必須是16位
        }
    }

    //默認密鑰向量
    private static byte[] _key1 = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF, 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };

    /// <summary>
    /// AES加密算法
    /// </summary>
    /// <param name="plainText">明文字符串</param>
    /// <returns>將加密后的密文轉換為Base64編碼,以便顯示</returns>
    public static string AESEncrypt(string plainText)
    {
        //分組加密算法
        SymmetricAlgorithm des = Rijndael.Create();
        byte[] inputByteArray = Encoding.UTF8.GetBytes(plainText);//得到需要加密的字節數組
        //設置密鑰及密鑰向量
        des.Key = Encoding.UTF8.GetBytes(Key);
        des.IV = _key1;
        byte[] cipherBytes = null;
        using (MemoryStream ms = new MemoryStream())
        {
            using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
            {
                cs.Write(inputByteArray, 0, inputByteArray.Length);
                cs.FlushFinalBlock();
                cipherBytes = ms.ToArray();//得到加密后的字節數組
                cs.Close();
                ms.Close();
            }
        }
        return Convert.ToBase64String(cipherBytes);
    }

    /// <summary>
    /// AES解密
    /// </summary>
    /// <param name="cipherText">密文字符串</param>
    /// <returns>返回解密后的明文字符串</returns>
    public static string AESDecrypt(string showText)
    {
        byte[] cipherText = Convert.FromBase64String(showText);

        SymmetricAlgorithm des = Rijndael.Create();
        des.Key = Encoding.UTF8.GetBytes(Key);
        des.IV = _key1;
        byte[] decryptBytes = new byte[cipherText.Length];
        using (MemoryStream ms = new MemoryStream(cipherText))
        {
            using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Read))
            {
                cs.Read(decryptBytes, 0, decryptBytes.Length);
                cs.Close();
                ms.Close();
            }
        }
        return Encoding.UTF8.GetString(decryptBytes).Replace("/0", "");   ///將字符串后尾的'/0'去掉
    }
}


Key的值可以放在config文件中,也可放入數據庫中。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产成人免费视频网站高清观看视频 | 日韩精品极品视频在线 | 干干射| 日韩性视频| 狠狠躁日日躁夜夜躁东南亚 | 91免费观看视频 | 韩国精品视频在线观看 | 希岛爱理在线 | 中文久久 | 国产精品一区二区三区网站 | 国产高清不卡一区 | 天天曰天天干 | 国产精品99久久免费观看 | 亚洲综合色自拍一区 | a级在线免费观看 | 欧美国产激情二区三区 | 天天舔天天爽 | 欧美日韩精品中文字幕 | 亚洲国产精品久久久久 | 一区二区精品视频 | 欧美精品在线一区二区三区 | 精品一区二区三区在线视频 | 久久com| 国产精品久久久久久久久免费高清 | 国产精品一区二区三区免费视频 | 国产精品久久一区二区三区 | 久久av一区二区三区 | 欧美一区永久视频免费观看 | 青草视频在线观看免费 | 久久91| 超碰在线观看免费 | 国产福利精品在线 | 欧洲精品久久久 | 日韩三区| 日本精品一区 | 国产视频一区二区在线观看 | 午夜妇女aaaa区片 | 羞羞视频网站在线观看 | 日韩欧美在线观看一区二区三区 | 国产欧美综合一区二区三区 | 欧洲精品一区二区 |