推 xv1987:感謝 .. 08/25 11:33
詳見 http://tinyurl.com/3zrelr
在.net中沒有直接的AES類別 要用AES請使用RijndaelManaged
DES的話請用DESCryptoServiceProvider
不同加解密算法流程都像底下那樣 只是要注意KEY的長度各演算法要求不同
....
.....
using System.Security.Cryptography;
......
....
//加密函式
private byte[] encrypt(string string_secretContent, string string_pwd)
{
//密碼轉譯一定都是用byte[] 所以把string都換成byte[]
byte[] byte_secretContent = Encoding.UTF8.GetBytes(string_secretContent);
byte[] byte_pwd = Encoding.UTF8.GetBytes(string_pwd);
//加解密函數的key通常都會有固定的長度 而使用者輸入的key長度不定 因此用hash過後的值當做key
MD5CryptoServiceProvider provider_MD5 = new MD5CryptoServiceProvider();
byte[] byte_pwdMD5 = provider_MD5.ComputeHash(byte_pwd);
//產生加密實體 如果要用其他不同的加解密演算法就改這裡(ex:3DES)
RijndaelManaged provider_AES = new RijndaelManaged();
ICryptoTransform encrypt_AES = provider_AES.CreateEncryptor(byte_pwdMD5, byte_pwdMD5);
//output就是加密過後的結果
byte[] output = encrypt_AES.TransformFinalBlock(byte_secretContent, 0, byte_secretContent.Length);
return output;
}
//解密函式
private string decrypt(byte[] byte_ciphertext, string string_pwd)
{
//密碼轉譯一定都是用byte[] 所以把string都換成byte[]
byte[] byte_pwd = Encoding.UTF8.GetBytes(string_pwd);
//加解密函數的key通常都會有固定的長度 而使用者輸入的key長度不定 因此用hash過後的值當做key
MD5CryptoServiceProvider provider_MD5 = new MD5CryptoServiceProvider();
byte[] byte_pwdMD5 = provider_MD5.ComputeHash(byte_pwd);
//產生解密實體
RijndaelManaged provider_AES = new RijndaelManaged();
ICryptoTransform decrypt_AES = provider_AES.CreateDecryptor(byte_pwdMD5, byte_pwdMD5);
//string_secretContent就是解密後的明文
byte[] byte_secretContent = decrypt_AES.TransformFinalBlock(byte_ciphertext, 0, byte_ciphertext.Length);
string string_secretContent = Encoding.UTF8.GetString(byte_secretContent);
return string_secretContent;
}
要測試的話就像這樣:
string string_secretContent = "科科 我是要加密的文件";
string string_pwd = "我是密碼";
//加密
byte[] byte_ciphertext = encrypt(string_secretContent, string_pwd);
//解密
string result = decrypt(byte_ciphertext, string_pwd);
※ 引述《xv1987 (cOOL)》之銘言:
: 我用的是環境是Visual studio 2005
: 想知道怎麼呼叫AES 和DES 這兩個加密演算法
: 我到MSDN這個網站跑了好久... 因為C#也是我剛接觸的語言
: 所以一直卡住...有人可以幫我解答嗎?
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 218.165.78.147