作者MRjk (efeewgf)
看板C_Sharp
标题Re: [问题] 请问C#要怎麽呼叫AES和DES演算法
时间Mon Aug 25 04:16:43 2008
详见
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
1F:推 xv1987:感谢 .. 08/25 11:33