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);
        }
    });
}

控制台日志:

要发送的登录数据:对象{loginusername: "test", loginpassword: "test"}

好parsererror

我的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有正确的答案,我不得不把单引号改成双引号