麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C# > 正文

C#實現(xiàn)對AES加密和解密的方法

2020-01-24 03:25:54
字體:
供稿:網(wǎng)友

AES簡介

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

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

復制代碼 代碼如下:

/// <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>將加密后的密文轉(zhuǎn)換為Base64編碼,以便顯示</returns>
    public static string AESEncrypt(string plainText)
    {
        //分組加密算法
        SymmetricAlgorithm des = Rijndael.Create();
        byte[] inputByteArray = Encoding.UTF8.GetBytes(plainText);//得到需要加密的字節(jié)數(shù)組
        //設置密鑰及密鑰向量
        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();//得到加密后的字節(jié)數(shù)組
                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文件中,也可放入數(shù)據(jù)庫中。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产精品一区99 | 久久99网 | 国产一区二区三区视频观看 | 成人精品 | 深夜影院一级毛片 | 欧美a∨亚洲欧美亚洲 | 激情福利视频 | 成人免费观看49www在线观看 | 国产午夜精品久久久久久免费视 | 激情亚洲一区二区 | 午夜激情视频网站 | 在线视频 欧美日韩 | 久久久久久久久久久久久九 | 国产成人高潮免费观看精品 | 九九视频精品在线观看 | 在线日韩av电影 | 日韩大片在线永久观看视频网站免费 | av电影免费看 | chinese xvideos gay | 91色一区二区三区 | 玩偶姐姐在线观看免费 | 狠狠干91| 欧美成人免费 | 国产成人在线播放视频 | 99这里精品| 毛片区| 爱高潮www亚洲精品 国产精品一区自拍 | 国产精品视频一区二区三区综合 | chinesehdxxxx无套 久久另类视频 | 国产一级桃视频播放 | 激情视频日韩 | 国产精品成人久久久久a级 欧美特黄一级高清免费的香蕉 | hdhdhdhd19日本人| 一级做a爱片毛片免费 | 亚洲第一成av人网站懂色 | 欧美一级免费在线观看 | 九九视频在线观看6 | lutube成人福利在线观看污 | 精品国产一区二区三区四区在线 | 成年免费在线视频 | 黄网站免费观看视频 |