dthh5038 2015-06-08 10:11
浏览 111
已采纳

使用php和md5登录和注册

I'm trying to hash the users password using md5 but I can't log in. It store the password hashed but when I do the login it doesn't work.Why? These are the functions (before I started using md5 it worked)

function checkLogin($username, $password)
{
    $password=md5($password);
    $checkLogin = "select * from users where username='$username' AND password='$password'";
    $check = mysql_query($checkLogin);
    return mysql_num_rows($check) > 0 ? true : false;
}

function setRegistration($username, $password) {
    $query = "insert into users (username, password) values('$username' , md5('$password'))";

    mysql_query($query)
    or die (mysql_error());
}
  • 写回答

3条回答 默认 最新

  • ds15812330851 2015-06-09 07:41
    关注

    I found the mistake.

    1. Column password was varchar(10) instead of varchar(32) (thank you for telling me that!)
    2. When I was trying to resolve the problem I wrote that :


    $check = $Database->checkLogin($_POST['username'], md5($_POST['password']));
    

    and then in the database function

    function checkLogin($username, $password)
        {
            $password=md5($password);
            $checkLogin = "select * from users where username='$username' AND password='$password'";
            $check = mysql_query($checkLogin);
            return mysql_num_rows($check) > 0 ? true : false;
        }
    

    So I was basically doing an hash of a already hashed password!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。