md5加密31位

 今天将其它服务器里的用户数据导入到新的系统数据库中 出现密码不匹配情况

查看原来数据库中密码得到结果位:

    原服务器密码               明文      正确32位密闻

67b14728ad9902aecba32e22fa4f6bd =》  000000  =》  e10adc3949ba59abbe56e057f2f883e

e1adc3949ba59abbe56e057f2f883e  =》  123456  =》e10adc3949ba59abbe56e057f2f883e

因原密码生成程序是.net写的,所以和我的php md5 加密的 结果不同,猜测可能是应该字节的问题

解决方案位:

  当用户输入密码后,先将密码正确md5加密32 匹配,正确继续往下执行,错误则再将原密码执行mymd5($str)方法 获取31位密码匹配,错误则提示密码错误,正确则将明文密码通过php md5执行加密后更新 数据库中密码。这样一段时间后更新了所有31位密码为32位。

function mymd5($str){

$psw = md5($str);//这是标准的32个字符的md5
$ret = '';
for( $i=0; $i<strlen($psw); $i+=2 )
{
$sub = substr($psw, $i, 2);
$ret .= ($sub[0]=='0'?$sub[1]:$sub);
}
return $ret;

}

原文地址:https://www.cnblogs.com/jackylee92/p/6128805.html