douxieqiu0651 2013-05-02 20:53
浏览 40
已采纳

MySQLi登录 - 没有错误但没有任何反应

I'm almost sure that the following line is wrong:

if ($mQuery){


But since num_rows won't work, I'm using it.
If the condition is wrong, what should I change it for?

My PHP login code:

<?php
    $mysqli = mysqli_connect("localhost","myUser","myPass","myDB");
    $error = false;

    $mQuery = $mysqli->query('SELECT * FROM usuarios WHERE usuario = '.$mysqli->real_escape_string(md5($_POST['usuario'])).' AND  senha = '.$mysqli->real_escape_string(md5($_POST['senha'])));

    if ($mQuery){
        $mAjax = (isset($_SERVER['HTTP_X_REQUESTED_WITH']) and strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest');
        if ($mAjax)
        {
            header('Cache-Control: no-cache, must-revalidate');
            header('Expires: '.date('r', time()+(86400*365)));
            header('Content-type: application/json');

            echo json_encode(array(
            'logged' => !$error
            ));
            exit();
        }
        elseif (!$error)
        {
            exit();
        }
    }
?>
  • 写回答

1条回答 默认 最新

  • dtrvzd1171 2013-05-02 21:07
    关注

    Try change your query from

    $mQuery = $mysqli->query('SELECT * FROM usuarios WHERE usuario = '.$mysqli->real_escape_string(md5($_POST['usuario'])).' AND  senha = '.$mysqli->real_escape_string(md5($_POST['senha'])));
    

    to

    $mQuery = $mysqli->query("SELECT * FROM usuarios WHERE usuario = '" . 
              $mysqli->real_escape_string(md5($_POST['usuario'])) . 
              "' AND  senha = '" . 
              $mysqli->real_escape_string(md5($_POST['senha'])) . "'");
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿