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

首頁 > 編程 > C# > 正文

C#簡單的加密類實例

2020-01-24 03:34:32
字體:
來源:轉載
供稿:網友
復制代碼 代碼如下:

public static class EncryptAndDecrypt
     {
         //加密
         public static string Encrypt(string input)
         {
             // 鹽值
             string saltValue = "saltValue";
             // 密碼值
             string pwdValue = "pwdValue";
             byte[] data = System.Text.UTF8Encoding.UTF8.GetBytes(input);
             byte[] salt = System.Text.UTF8Encoding.UTF8.GetBytes(saltValue);
             // AesManaged - 高級加密標準(AES) 對稱算法的管理類
             System.Security.Cryptography.AesManaged aes = new System.Security.Cryptography.AesManaged();
             // Rfc2898DeriveBytes - 通過使用基于 HMACSHA1 的偽隨機數生成器,實現基于密碼的密鑰派生功能 (PBKDF2 - 一種基于密碼的密鑰派生函數)
             // 通過 密碼 和 salt 派生密鑰
             System.Security.Cryptography.Rfc2898DeriveBytes rfc = new System.Security.Cryptography.Rfc2898DeriveBytes(pwdValue, salt);
             /**/
             /*
          * AesManaged.BlockSize - 加密操作的塊大小(單位:bit)
          * AesManaged.LegalBlockSizes - 對稱算法支持的塊大小(單位:bit)
          * AesManaged.KeySize - 對稱算法的密鑰大小(單位:bit)
          * AesManaged.LegalKeySizes - 對稱算法支持的密鑰大小(單位:bit)
          * AesManaged.Key - 對稱算法的密鑰
          * AesManaged.IV - 對稱算法的密鑰大小
          * Rfc2898DeriveBytes.GetBytes(int 需要生成的偽隨機密鑰字節數) - 生成密鑰
          */
             aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
             aes.KeySize = aes.LegalKeySizes[0].MaxSize;
             aes.Key = rfc.GetBytes(aes.KeySize / 8);
             aes.IV = rfc.GetBytes(aes.BlockSize / 8);
             // 用當前的 Key 屬性和初始化向量 IV 創建對稱加密器對象
             System.Security.Cryptography.ICryptoTransform encryptTransform = aes.CreateEncryptor();
             // 加密后的輸出流
             System.IO.MemoryStream encryptStream = new System.IO.MemoryStream();
             // 將加密后的目標流(encryptStream)與加密轉換(encryptTransform)相連接
             System.Security.Cryptography.CryptoStream encryptor = new System.Security.Cryptography.CryptoStream
                 (encryptStream, encryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
             // 將一個字節序列寫入當前 CryptoStream (完成加密的過程)
             encryptor.Write(data, 0, data.Length);
             encryptor.Close();
             // 將加密后所得到的流轉換成字節數組,再用Base64編碼將其轉換為字符串
             string encryptedString = Convert.ToBase64String(encryptStream.ToArray());
             return encryptedString;
         }

 
         #region silverlight密碼解密
         /**/
         /// <summary>
         /// 解密數據
         /// </summary>
         /// <param name="input">加密后的字符串</param>
         /// <returns>加密前的字符串</returns>
         public static string Decrypt(string input)
         {
             // 鹽值(與加密時設置的值一致)
             string saltValue = "saltValue";
             // 密碼值(與加密時設置的值一致)
             string pwdValue = "pwdValue";
             byte[] encryptBytes = Convert.FromBase64String(input);
             byte[] salt = Encoding.UTF8.GetBytes(saltValue);
             System.Security.Cryptography.AesManaged aes = new System.Security.Cryptography.AesManaged();
             System.Security.Cryptography.Rfc2898DeriveBytes rfc = new System.Security.Cryptography.Rfc2898DeriveBytes(pwdValue, salt);
             aes.BlockSize = aes.LegalBlockSizes[0].MaxSize;
             aes.KeySize = aes.LegalKeySizes[0].MaxSize;
             aes.Key = rfc.GetBytes(aes.KeySize / 8);
             aes.IV = rfc.GetBytes(aes.BlockSize / 8);
             // 用當前的 Key 屬性和初始化向量 IV 創建對稱解密器對象
             System.Security.Cryptography.ICryptoTransform decryptTransform = aes.CreateDecryptor();
             // 解密后的輸出流
             MemoryStream decryptStream = new MemoryStream();
             // 將解密后的目標流(decryptStream)與解密轉換(decryptTransform)相連接
             System.Security.Cryptography.CryptoStream decryptor = new System.Security.Cryptography.CryptoStream(
                 decryptStream, decryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
             // 將一個字節序列寫入當前 CryptoStream (完成解密的過程)
             decryptor.Write(encryptBytes, 0, encryptBytes.Length);
             decryptor.Close();
             // 將解密后所得到的流轉換為字符串
             byte[] decryptBytes = decryptStream.ToArray();
             string decryptedString = UTF8Encoding.UTF8.GetString(decryptBytes, 0, decryptBytes.Length);
             return decryptedString;
         }
         #endregion
     }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人国产综合 | 91精品国产91 | 伦一区二区三区中文字幕v亚洲 | 久久亚洲第一 | 成年人在线免费播放视频 | 国产美女爽到喷白浆的 | 日本a∨精品中文字幕在线 欧美1—12sexvideos | 国产精品中文在线 | 欧美国产一级片 | 国产精品亚洲欧美一级在线 | 羞羞视频免费网站 | 欧美国产一区二区三区 | 黄色大片大毛片 | 国产亚洲精品网站 | 99精品视频久久精品视频 | 亚欧美一区二区 | 鲁丝片一区二区三区免费入口 | 中国av中文字幕 | porno video hd 365hd| 在线免费观看毛片视频 | 成人黄色短视频在线观看 | 欧美黄色性视频 | 黄色网电影 | 久久国产精品99国产 | 鲁人人人鲁人人鲁精品 | 人人玩人人爽 | 少妇淫片免费一级毛片 | 色婷婷久久久亚洲一区二区三区 | 高清av免费 | 久久精品日韩 | 国产一区精品在线观看 | 国人精品视频在线观看 | 黄色片网站免费观看 | 国产a级网站 | av在线免费看网站 | 国产 日韩 亚洲 欧美 | 一级黄色片在线看 | 欧美wwwwww | 综合精品一区 | 国产一区二区欧美 | 狼人狠狠干 |