C#簡單的加密類實例
更新時間:2013年03月04日 16:20:29 作者:
AesManaged - 高級加密標準(AES) 對稱算法的管理類
復制代碼 代碼如下:
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 的偽隨機數(shù)生成器,實現(xiàn)基于密碼的密鑰派生功能 (PBKDF2 - 一種基于密碼的密鑰派生函數(shù))
// 通過 密碼 和 salt 派生密鑰
System.Security.Cryptography.Rfc2898DeriveBytes rfc = new System.Security.Cryptography.Rfc2898DeriveBytes(pwdValue, salt);
/**/
/*
* AesManaged.BlockSize - 加密操作的塊大?。▎挝唬篵it)
* AesManaged.LegalBlockSizes - 對稱算法支持的塊大?。▎挝唬篵it)
* AesManaged.KeySize - 對稱算法的密鑰大?。▎挝唬篵it)
* AesManaged.LegalKeySizes - 對稱算法支持的密鑰大?。▎挝唬篵it)
* AesManaged.Key - 對稱算法的密鑰
* AesManaged.IV - 對稱算法的密鑰大小
* Rfc2898DeriveBytes.GetBytes(int 需要生成的偽隨機密鑰字節(jié)數(shù)) - 生成密鑰
*/
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 創(chuàng)建對稱加密器對象
System.Security.Cryptography.ICryptoTransform encryptTransform = aes.CreateEncryptor();
// 加密后的輸出流
System.IO.MemoryStream encryptStream = new System.IO.MemoryStream();
// 將加密后的目標流(encryptStream)與加密轉(zhuǎn)換(encryptTransform)相連接
System.Security.Cryptography.CryptoStream encryptor = new System.Security.Cryptography.CryptoStream
(encryptStream, encryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
// 將一個字節(jié)序列寫入當前 CryptoStream (完成加密的過程)
encryptor.Write(data, 0, data.Length);
encryptor.Close();
// 將加密后所得到的流轉(zhuǎn)換成字節(jié)數(shù)組,再用Base64編碼將其轉(zhuǎn)換為字符串
string encryptedString = Convert.ToBase64String(encryptStream.ToArray());
return encryptedString;
}
#region silverlight密碼解密
/**/
/// <summary>
/// 解密數(shù)據(jù)
/// </summary>
/// <param name="input">加密后的字符串</param>
/// <returns>加密前的字符串</returns>
public static string Decrypt(string input)
{
// 鹽值(與加密時設(shè)置的值一致)
string saltValue = "saltValue";
// 密碼值(與加密時設(shè)置的值一致)
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 創(chuàng)建對稱解密器對象
System.Security.Cryptography.ICryptoTransform decryptTransform = aes.CreateDecryptor();
// 解密后的輸出流
MemoryStream decryptStream = new MemoryStream();
// 將解密后的目標流(decryptStream)與解密轉(zhuǎn)換(decryptTransform)相連接
System.Security.Cryptography.CryptoStream decryptor = new System.Security.Cryptography.CryptoStream(
decryptStream, decryptTransform, System.Security.Cryptography.CryptoStreamMode.Write);
// 將一個字節(jié)序列寫入當前 CryptoStream (完成解密的過程)
decryptor.Write(encryptBytes, 0, encryptBytes.Length);
decryptor.Close();
// 將解密后所得到的流轉(zhuǎn)換為字符串
byte[] decryptBytes = decryptStream.ToArray();
string decryptedString = UTF8Encoding.UTF8.GetString(decryptBytes, 0, decryptBytes.Length);
return decryptedString;
}
#endregion
}
相關(guān)文章
WPF利用TabControl控件實現(xiàn)拖拽排序功能
在UI交互中,拖拽操作是一種非常簡單友好的交互,這篇文章主要為大家介紹了WPF如何利用TabControl控件實現(xiàn)拖拽排序功能,需要的小伙伴可以參考一下2023-10-10
C# List實現(xiàn)行轉(zhuǎn)列的通用方案
本篇通過行轉(zhuǎn)列引出了System.Linq.Dynamic,并且介紹了過濾功能,具有很好的參考價值。下面跟著小編一起來看下吧2017-03-03
Unity的IPostprocessBuild實用案例深入解析
這篇文章主要為大家介紹了Unity的IPostprocessBuild實用案例深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05

