.NET MD5加密解密代碼解析
MD5簡介:
是讓大容量信息在用數(shù)字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個任意長度的字節(jié)串變換成一定長的大整數(shù))。不管是MD2、MD4還是MD5,它們都需要獲得一個隨機長度的信息并產(chǎn)生一個128位的信息摘要。雖然這些算法的結(jié)構(gòu)或多或少有些相似,但MD2的設(shè)計與MD4和MD5完全不同,那是因為MD2是為8位機器做過設(shè)計優(yōu)化的,而MD4和MD5卻是面向32位的電腦。這三個算法的描述和C語言源代碼在Internet RFCs 1321中有詳細的描述,這是一份最權(quán)威的文檔,由Ronald L. Rivest在1992年8月向IETF提交。
代碼:
string JiaMi = Md5Encrypt(LoginPwd);
string JieMi = Md5Decrypt(JiaMi);
#region MD5加密
/// <summary>
/// MD5加密
/// </summary>
/// <param name="strSource">需要加密的字符串</param>
/// <returns>MD5加密后的字符串</returns>
public static string Md5Encrypt(string strSource)
{
//把字符串放到byte數(shù)組中
byte[] bytIn = System.Text.Encoding.Default.GetBytes(strSource);
//建立加密對象的密鑰和偏移量
byte[] iv = { 102, 16, 93, 156, 78, 4, 218, 32 };//定義偏移量
byte[] key = { 55, 103, 246, 79, 36, 99, 167, 3 };//定義密鑰
//實例DES加密類
DESCryptoServiceProvider mobjCryptoService = new DESCryptoServiceProvider();
mobjCryptoService.Key = iv;
mobjCryptoService.IV = key;
ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor();
//實例MemoryStream流加密密文件
System.IO.MemoryStream ms = new System.IO.MemoryStream();
CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);
cs.Write(bytIn, 0, bytIn.Length);
cs.FlushFinalBlock();
return System.Convert.ToBase64String(ms.ToArray());
}
#endregion
#region MD5解密
/// <summary>
/// MD5解密
/// </summary>
/// <param name="Source">需要解密的字符串</param>
/// <returns>MD5解密后的字符串</returns>
public static string Md5Decrypt(string Source)
{
//將解密字符串轉(zhuǎn)換成字節(jié)數(shù)組
byte[] bytIn = System.Convert.FromBase64String(Source);
//給出解密的密鑰和偏移量,密鑰和偏移量必須與加密時的密鑰和偏移量相同
byte[] iv = { 102, 16, 93, 156, 78, 4, 218, 32 };//定義偏移量
byte[] key = { 55, 103, 246, 79, 36, 99, 167, 3 };//定義密鑰
DESCryptoServiceProvider mobjCryptoService = new DESCryptoServiceProvider();
mobjCryptoService.Key = iv;
mobjCryptoService.IV = key;
//實例流進行解密
System.IO.MemoryStream ms = new System.IO.MemoryStream(bytIn, 0, bytIn.Length);
ICryptoTransform encrypto = mobjCryptoService.CreateDecryptor();
CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read);
StreamReader strd = new StreamReader(cs, Encoding.Default);
return strd.ReadToEnd();
}
#endregion
另一種MD5加密方法:
MD5加密簡單的說就是把一段明文 通過某種運算方式 求出密文。例如:明文為:abcdefg 通過一些列運算 得到 密文 7ac66c0f148de9519b8bd264312c4d64
它具有兩個特性:1.無碰撞,2.不可逆。
無碰撞是指:
7ac66c0f148de9519b8bd264312c4d64 這段密文 只能由 abcdefg 這段明文得到,除此之外其他的 明文加密后 其值 絕對不會等于7ac66c0f148de9519b8bd264312c4d64,也就是說 沒有那兩個明文 加密后 會得到相同的密文。
不可逆是指:
明文通過加密后得到密文,而無法通過密文 求出明文。也就是說 當(dāng)我們知道明文 adcdefg 可以通過加密得到 7ac66c0f148de9519b8bd264312c4d64,但是我們?nèi)绻?某段文字 加密后 得到7ac66c0f148de9519b8bd264312c4d64,卻無法算出 7ac66c0f148de9519b8bd264312c4d64這段文字是由誰加密而來的。
例如 用戶設(shè)置的密碼 為 abcdefg,而存儲的時候 我們存儲的是 abcdefg加密過之后得到的值 7ac66c0f148de9519b8bd264312c4d64,那么用戶再次登錄時 會輸入密碼abcdefg,我們?nèi)绾伪容^兩者是否相等?
我們無法通過 加密后的值換算出 加密前的值,因此 我們通常的做法是,把用戶再次登錄時 輸入的密碼 再次加密 和數(shù)據(jù)庫中 存放的值進行比對,如果相等 則說明輸入的密碼正確。
需要引用 using System.Web.Security;
FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower();
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- ASP.NET中DES加密與解密MD5加密幫助類的實現(xiàn)代碼
- VB.NET實現(xiàn)的MD5加密算法示例【32位】
- asp.net實現(xiàn)的MD5加密和DES加解密算法類完整示例
- asp.net實現(xiàn)md5加密
- vb 中的MD5加密在asp.net中的實現(xiàn)
- asp.net中使用cookie與md5加密實現(xiàn)記住密碼功能的實現(xiàn)代碼
- ASP.NET中MD5與SHA1加密的幾種方法
- 徹底解決ASP.NET MD5加密中文結(jié)果和ASP不一致的問題
- asp.net下常用的加密算法MD5、SHA-1應(yīng)用代碼
- asp.net中MD5 16位和32位加密函數(shù)
- ASP.net中md5加密碼的方法
- .net core使用MD5加密解密字符串
相關(guān)文章
ASP.NET?Core使用Swagger/OpenAPI規(guī)范
這篇文章介紹了ASP.NET?Core使用Swagger/OpenAPI規(guī)范的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
Microsoft SQL Server 2005 Express 遠程訪問設(shè)置詳述,100%成功篇
Microsoft SQL Server 2005 Express Edition是Microsoft數(shù)據(jù)庫的低端解決方案,是免費的,并且可以隨軟件免費發(fā)布,而就其數(shù)據(jù)庫功能對于一般的企業(yè)級應(yīng)用已足夠了。但 默認安裝時只允許本地訪問,而不能遠程訪問。2009-03-03
DataGridView中綁定DataTable數(shù)據(jù)及相關(guān)操作實現(xiàn)代碼
DataGridView中綁定DataTable數(shù)據(jù)及相關(guān)操作2010-02-02
asp.net 使用Silverlight操作ASPNETDB數(shù)據(jù)庫
asp.net下使用Silverlight操作ASPNETDB數(shù)據(jù)庫的實現(xiàn)代碼2010-01-01

