Heim >Backend-Entwicklung >C#.Net-Tutorial >ASP.NET-Datenbankkennwort: Ausführliche Erläuterung des MD5-Verschlüsselungsalgorithmus
Im Prozess der Softwareentwicklung ist die Speicherung wichtiger Informationen wie Benutzerkennwörter unweigerlich erforderlich. In den meisten Fällen wird das Passwort des Benutzers in der Datenbank gespeichert. Wenn Sie keine Vertraulichkeitsmaßnahmen hinzufügen und diese direkt im Klartext speichern, kann es leicht zum Verlust persönlicher Daten der Benutzer kommen, was zu unvorhersehbaren Verlusten für Unternehmen und Benutzer führt.
Derzeit gibt es viele häufig verwendete Speicheralgorithmen für die Passwortverschlüsselung, wie zum Beispiel: MD5
, 3DES
, AES
, SHA1
usw.
Heute werden wir hauptsächlich den MD5-Verschlüsselungsalgorithmus vorstellen.
Was ist der MD5-Algorithmus? Gruppen werden zur Verarbeitung der Eingabeinformationen verwendet und jede Gruppe wird nach einer Reihe in 16 32-Bit-Untergruppen unterteilt Nach der Verarbeitung wird die Ausgabe des Algorithmus durch vier 32-Bit-Gruppen verkettet, um einen 128-Bit-Hash-Wert zu generieren.
Verwenden Sie ASP.NET, um den Passwortfeldwert zu verschlüsseln. Der Code lautet wie folgt:
using System.Security.Cryptograhoy;//引入MD5加密命名空间 public string GetMD5(string strPwd) { //将要加密的字符串加上前缀与后缀后再加密 string cl = DateTime.Now.Month + strPwd + DateTime.Now.Day; string pwd = ""; //实例化一个MD5对象 MD5 md5 = MD5.Create(); //加密后是一个字节类型的数组,要注意编码UTF8/Unicode等的选择 byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl)); //翻转生成的MD5码 s.Reverse(); //通过循环,将字节类型的数组转换为字符串 //只取MD5码的一部分,这样恶意访问者无法知道取的是哪几位 for(int i = 3;i < s.Length-1; i++) { //将得到的字符串使用十六进制类型格式化。格式化后的字符是小写的字母,如果使用大写(X),则格式化后的字符是大写字母 //进一步对生成的MD5码做一些改造 pwd = pwd + (s[i] < 198 ? s[i] + 28 : s[i]).ToString("X"); } return pwd; }Hinweis
Wenn Sie verwenden einfach MD5. Der vom Algorithmus generierte Hashwert kann geknackt werden. Daher müssen wir im eigentlichen Entwicklungsprozess den MD5-Algorithmus in Kombination mit dem Salt-Algorithmus verwenden, um eine verschlüsselte Zeichenfolge zu generieren, die nicht geknackt werden kann.
Das obige ist der detaillierte Inhalt vonASP.NET-Datenbankkennwort: Ausführliche Erläuterung des MD5-Verschlüsselungsalgorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!