繁体   English   中英

AJAX 正在运行错误函数而不是成功函数

[英]AJAX is running error function instead of success function

我试图让我的数据库登录工作。 但是我的 AJAX 调用一直在运行错误函数而不是成功,我很难理解为什么。

function doLogin() {
    var formData = ConvertFormToJSON("#login-form");
    console.log('login data to send: ', formData);

    $.ajax({
        url: 'php/login-session.php',
        type: 'POST',
        dataType: 'JSON',
        data: formData,
        success: function(logindata) {
            console.log('login data returned: ', logindata);

            var status = logindata['status'];
            if(status == "fail"){
                $("#loginerror").html(logindata['msg']);
                $("#loginerror").cs('display', 'block');
            } else {
                getUserProfileInfo();
                $("login-form").trigger('reset');
            }
        },
        error: function(jqXHR, textStatus, errorThrown){
            console.log(jqXHR.statusText, textStatus);
        }
    });
}

控制台日志:

要发送的登录数据:对象{登录用户名:“测试”,登录密码:“测试”}

好的解析器错误

我的 login-session.php 代码是:

<?php

if (session_status() == PHP_SESSION_NONE) {
    session_start();
}

$DBhost = 'localhost';
$DBuser = 'root';
$DBpass = 'root';
$DBname = 'anamadeus';

$methodType = $_SERVER['REQUEST_METHOD'];
$data = array('status' => 'fail', 'msg' => '$methodType');

if($methodType === 'POST'){
    //Check AJAX
    if(isset($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {

        if(isset($_POST['loginusername']) && !empty($_POST['loginusername']) && isset($_POST["loginpassword"]) && !empty($_POST["loginpassword"])){

            // get the data from the post and store in variables
            $username = $_POST["loginusername"];
            $password = $_POST["loginpassword"];

            try {
                $conn = new PDO('mysql:host=$DBhost;dbname=$DBname', $DBuser, $DBpass);
                $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

                $sql = 'SELECT * FROM user WHERE username = :log AND password = :pwd';

                $statement = $conn->prepare($sql);
                $statement->execute(array(":log" => $username, ":pwd" => $password));

                // this should be one if there's a user by that user value and password value
                $count = $statement->rowCount();

                if($count > 0){
                    $rows = $statement->fetchAll(PDO::FETCH_ASSOC);
                    $returnedUsername = $rows[0]['username'];
                    $returnedPassword = $rows[0]['password'];

                    $_SESSION['username'] = $returnedUsername;
                    $_SESSION['loggedin'] = true;

                    $sid=session_id();
                    $data = array("status" => "success", "sid" => $sid);
                } else {
                    $data = array("status" => "fail", "msg" => "User name and/or password not correct.");
                }
            } catch(PDOException $e) {
                $data = array("status" => "fail", "msg" => $e->getMessage());
            }

        } else {
            $data = array("status" => "fail", "msg" => "Either login or password were absent.");
        }

    } else {
        // not AJAX
        $data = array("status" => "fail", "msg" => "Has to be an AJAX call.");
    }
} else {
    // simple error message, only taking POST requests
    $data = array("status" => "fail", "msg" => "Error: only POST allowed.");
}

echo json_encode($data, JSON_FORCE_OBJECT);

?>

请帮我。

我在 MAMP 上运行我的数据库和 php

Epascarello 有正确的答案,我不得不将单引号更改为双引号。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM