Javascript 不使用AJAX获取发布数据
我想通过将文本框数据发布到php来检查AJAX的“blur()”上是否存在用户eamil,我可以在使用firebug时看到发布的数据,但我一直遇到这样的错误:未定义索引:数据,我已经尽了很大努力,但尚未解决此问题。这是javascript:Javascript 不使用AJAX获取发布数据,javascript,php,jquery,Javascript,Php,Jquery,我想通过将文本框数据发布到php来检查AJAX的“blur()”上是否存在用户eamil,我可以在使用firebug时看到发布的数据,但我一直遇到这样的错误:未定义索引:数据,我已经尽了很大努力,但尚未解决此问题。这是javascript: $(document).ready(function() { $('#regEmail').blur(function() { var Email = $('#regEmail').val(); var dat
$(document).ready(function() {
$('#regEmail').blur(function() {
var Email = $('#regEmail').val();
var data = '{Email:' + Email + '}';
$.ajax({
type: "POST",
url: "register.php",
data: data,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (response) {
var result = response.exists;
if (result == true) {
alert('Email already exists!');
return;
}
else {
alert("Does not exist!");
}
}
});
});
});
这是php代码:
if (isset($_POST['data']))
{
$db = new mysqli("localhost", "xxxx", "xxxxxxx", "xxxxxxx");
$data = $_POST['data'];
json_decode($data);
$Email = $data->fetch_assoc();
$Email = $Email["Email"];
$sql = "SELECT COUNT(*) as isExisting FROM users WHERE user_email='$Email'";
$sql_result = $db->query($sql);
$result = $sql_result->fetch_assoc();
if ($result["isExisting"] > 0)
{
$response = json_encode(array('exists' => true));
} else {
$response = json_encode(array('exists' => false));
}
echo $response;
print json_encode($_POST);
}
我添加了“if(isset($\u POST['data'])”来检查POST数据是否已设置,但显然没有设置。使用jQuery.ajax方法,
data
参数应该是一个JSON对象。
你应该写:
var data = { 'Email': Email };
$.ajax({
type: "POST",
url: "register.php",
data: data,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (response) {
var result = response.exists;
if (result == true) {
alert('Email already exists!');
return;
}
else {
alert("Does not exist!");
}
}
}
);
然后您可以通过使用jQuery.ajax方法访问
$\u POST['email']
在服务器端使用电子邮件值,数据
参数应该是一个JSON对象。
你应该写:
var data = { 'Email': Email };
$.ajax({
type: "POST",
url: "register.php",
data: data,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (response) {
var result = response.exists;
if (result == true) {
alert('Email already exists!');
return;
}
else {
alert("Does not exist!");
}
}
}
);
然后,您可以通过访问
$\u POST['email']
$\u POST
用于键/值格式的URL编码数据,在服务器端使用电子邮件值。您发送的是不同的原始JSON。使用当前的Javascript,您需要使用$HTTP\u RAW\u POST\u DATA
在PHP端获取JSON
这可以做到:
var data = { Email : Email };
$.ajax({
type: "POST",
url: "register.php",
data: { data : JSON.stringify(data) },
dataType: "json",
success: function (response) {
var result = response.exists;
if (result == true) {
alert('Email already exists!');
return;
}
else {
alert("Does not exist!");
}
}
});
变化:
变量到Javascript对象(非JSON)数据
- 作为表单编码的POST数据发送,其中一个输入(数据)是
数据的JSON编码版本
- 删除了JSON内容类型
$data = $_POST['data'];
$email = json_decode($data);
$Email = $Email->Email;
可以使用数组语法,但前提是将
json\u decode()
的第二个参数设置为true
json_decode()
不更新作为参数传递的变量,必须捕获返回值。$\u POST
用于键/值格式、URL编码的数据。您发送的是不同的原始JSON。使用当前的Javascript,您需要使用$HTTP\u RAW\u POST\u DATA
在PHP端获取JSON
这可以做到:
var data = { Email : Email };
$.ajax({
type: "POST",
url: "register.php",
data: { data : JSON.stringify(data) },
dataType: "json",
success: function (response) {
var result = response.exists;
if (result == true) {
alert('Email already exists!');
return;
}
else {
alert("Does not exist!");
}
}
});
变化:
变量到Javascript对象(非JSON)数据
- 作为表单编码的POST数据发送,其中一个输入(数据)是
数据的JSON编码版本
- 删除了JSON内容类型
$data = $_POST['data'];
$email = json_decode($data);
$Email = $Email->Email;
可以使用数组语法,但前提是将
json\u decode()
的第二个参数设置为true
json_decode()
不更新作为参数传递的变量,您必须捕获返回值。如果使用form
请求样式,那么“json”content type
是多余的。如果我按照您的建议执行,电子邮件将以“email=xxxxxx%40gmail.com”而不是“email”的形式发布=xxxxxx@gmail.com". php仍然没有收到帖子。如果你使用表单
请求样式,那么“json”内容类型
是多余的。如果我按照你建议的那样做,电子邮件将以“email=xxxxxx%40gmail.com”而不是“email”的形式发布=xxxxxx@gmail.com". php仍然没有收到帖子。事实上,它做到了,它消除了错误,但是javascript警报从未弹出,你能告诉我为什么吗?我认为成功部分没有执行,但我不知道为什么代码>来自PHP代码。这导致响应是无效的JSON。没有问题:)编码愉快!事实上它做到了,它消除了错误,但是javascript警报从未弹出,你能告诉我为什么吗?我认为成功部分没有执行,但我不知道为什么代码>来自PHP代码。这导致响应是无效的JSON。没有问题:)编码愉快!