我得到了
Uncaught SyntaxError: Unexpected token < x.extend.parseJSON jQuery.js:4
$.ajax.success Login.js:15
c jQuery.js:4
p.fireWith jQuery.js:4
k jQuery.js:6
r
jQuery是一个全新下载,我登录js的错误就在这行
var json = jQuery.parseJSON(data);
编辑这里是登录php页面,如果你需要javascript告诉我。您也会说这比设置标准表单和页面更有效:
<?php
require("./../config.php");
if (!isset($_POST['req']))
{
die("No request provided.");
}
else
{
if ($_POST['req'] == "login")
{
$json = array("success"=>false, "msg"=>"", "req"=>"login");
if (!isset($_POST['user']) || empty($_POST['user']))
{
$json['success'] = false;
$json['msg'] = "No user provided";
}
else
{
if (!isset($_POST['pass']) || empty($_POST['pass']))
{
$json['success'] = false;
$json['msg'] = "No password provided";
}
else
{
$user = mysql_real_escape_string($_POST['user']);
$password = mysql_real_escape_string($_POST['pass']);
$password = hash("sha512", $password);
$query = mysql_query("SELECT `id` FROM `users` WHERE `username` = '" . $user . "' AND `password` = '" . mysql_real_escape_string($password) . "' LIMIT 1");
if (mysql_num_rows($query))
{
$sessID = mysql_real_escape_string(session_id());
$hash = mysql_real_escape_string(hash("sha512", $sessID.$_SERVER['HTTP_USER_AGENT']));
$userData = mysql_fetch_assoc($query);
$expires = time() + (60 * 15);
mysql_query("INSERT INTO `active_users` (`user`, `session_id`, `hash`, `expires`) VALUES (" . (int) $userData['id'] . ", '" . $sessID . "', '" . $hash . "', " . $expires . ")");
$json['success'] = true;
$json['msg'] = "Logged in";
}
else
{
$json['success'] = false;
$json['msg'] = "Username or password are incorrect.";
}
}
}
print(json_encode($json));
}
}
?>
答案 0 :(得分:4)
从jQuery 1.9开始,$.parseJSON
将抛出JavaScript错误而不是返回null
。所以你的json无法显示错误。
来自jQuery文档:
“在jQuery 1.9之前,如果传递空字符串,null或未定义,$ .parseJSON返回null而不是抛出错误,即使它们不是有效的JSON。”
要防止JS抛出错误,请执行以下操作:
try {
var json = $.parseJSON(data);
//if code below here runs, means json is valid
} catch(e){
//if code below here runs, means json is invalid
}
Ps。:发布您的JSON,以便我们知道问题所在。您可以在console.log(data);
之前添加try
(如果您使用我的代码)。