MD5的简介:MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
注:MD5常用于密码加密。
实战应用:wpf项目中要使用MD5来加密敏感数据保存入库,但是又要可以实现记住密码,MD5是不可逆的无法进行解密,而记住密码保存到本地文件的也是密文,记住密码后再次登录就要先解密一遍赋值给当前界面的密码框,然后点击登录再进行加密与数据库中的作对比,这样就不能使用MD5去进行记住密码了。这里就要使用DES来记住密码保存本地,登录的时候,获取记住的信息DES解密,点击登录再MD5加密即可。
实现过程:
获取界面登录信息
//获取登录信息 loginRecord.Name = tbName.Text.Trim(); loginRecord.MD5Pwd = TrialHelper.GetMD5(tbPwd.Password); //保存到数据库MD5方式 loginRecord.Pwd = TrialHelper.EncryptDES(tbPwd.Password);//记住密码des方式,保存到本地 loginRecord.IsSavePwd = (bool)cbSaveName.IsChecked; loginRecord.IsAutoLogin = (bool)cbAutoLogin.IsChecked;
实现登录
//用MD5加密的去登录 LoginService.LoginInfo lgInfo=LoginService.LoginService.GetLoginUserInfo(loginRecord.Name, loginRecord.MD5Pwd);
登录成功后记住密码保存账户信息到本地文件
//登录成功后保存配置文件 XmlHelper.XmlSerializeToFile(loginRecord, "LoginInfo.ini");
记住密码登录方式和自动登录方式,再从配置文件读取账户信息赋值到界面,最后点击登录逻辑还是一样,经MD5加密去登录与数据库中的密文进行对比。
//获取登录配置信息并赋值到界面,LoginInfo记录的密码是加密的 loginRecord = XmlHelper.XmlDeserializeFromFile<LoginRecord>("LoginInfo.ini"); if (loginRecord != null) { tbName.Text = loginRecord.Name;//用户名输入框赋值 tbPwd.Password = TrialHelper.DecryptDES(loginRecord.Pwd);//密码输入框赋值,Des解密后的值 cbAutoLogin.IsChecked = loginRecord.IsAutoLogin;//自动登录选框 cbSaveName.IsChecked = loginRecord.IsSavePwd; //记住密码选框 if (loginRecord.IsAutoLogin)//自动登录 { btnLogin_Click(null, null); } }