zoukankan      html  css  js  c++  java
  • 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;

    }

  • 相关阅读:
    MySQL数据库小结
    使用Python操作MySQL数据库
    MySQL索引原理
    MySQL性能分析之Explain
    201907 TIOBE 编程语言排行榜-Python坐稳第三
    MySQL索引的数据结构-B+树介绍
    MySQL多表查询综合练习答案
    MySQL记录操作
    MySQL多表查询
    javascript实现无缝上下滚动(转)
  • 原文地址:https://www.cnblogs.com/jackylee92/p/6128805.html
Copyright © 2011-2022 走看看