剛剛學(xué)會(huì)的C#的加密與解密(三種)md5加密/RSA加密與解密/DES加密。也是剛剛申請(qǐng)的blog隨便發(fā)布一下。
(一)、MD5加密
MD5 md5 = new MD5CryptoServicePRovider();
byte[] palindata = Encoding.Default.GetBytes(textBox1.Text);//將要加密的字符串轉(zhuǎn)換為字節(jié)數(shù)組
byte[] encryptdata = md5.ComputeHash(palindata);//將字符串加密后也轉(zhuǎn)換為字符數(shù)組
textBox2.Text = Convert.ToBase64String(encryptdata);//將加密后的字節(jié)數(shù)組轉(zhuǎn)換為加密字符串
(二)、RAS加密
首先聲明全局變量:CspParameters param;
RAS加密:
param = new CspParameters();
param.KeyContainerName = "Olive";//密匙容器的名稱,保持加密解密一致才能解密成功
using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(param))
{
byte[] plaindata = Encoding.Default.GetBytes(textBox1.Text);//將要加密的字符串轉(zhuǎn)換為字節(jié)數(shù)組
byte[] encryptdata = rsa.Encrypt(plaindata, false);//將加密后的字節(jié)數(shù)據(jù)轉(zhuǎn)換為新的加密字節(jié)數(shù)組
textBox2.Text = Convert.ToBase64String(encryptdata);//將加密后的字節(jié)數(shù)組轉(zhuǎn)換為字符串
}
RAS解密:
param = new CspParameters();
param.KeyContainerName = "Olive";
using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(param))
{
byte[] encryptdata = Convert.FromBase64String(this.textBox2.Text);
byte[] decryptdata = rsa.Decrypt(encryptdata, false);
textBox3.Text = Encoding.Default.GetString(decryptdata);
}
DES加密:
首先聲明全局變量
byte[] buffer;
DESCryptoServiceProvider DesCSP = new DESCryptoServiceProvider();
DES解密:
MemoryStream ms = new MemoryStream(buffer);//將加密后的字節(jié)數(shù)據(jù)加入內(nèi)存流中
CryptoStream cryStream = new CryptoStream(ms, DesCSP.CreateDecryptor(), CryptoStreamMode.Read);//內(nèi)存流連接到解密流中
StreamReader sr = new StreamReader(cryStream);
textBox5.Text = sr.ReadLine();//將解密流讀取為字符串
sr.Close();
cryStream.Close();
ms.Close();
好了,就先寫到這吧,界面就不展示了。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注