今天将其它服务器里的用户数据导入到新的系统数据库中 出现密码不匹配情况
查看原来数据库中密码得到结果位:
原服务器密码 明文 正确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;
}