Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/247.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 不使用AJAX获取发布数据_Javascript_Php_Jquery - Fatal编程技术网

Javascript 不使用AJAX获取发布数据

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

我想通过将文本框数据发布到php来检查AJAX的“blur()”上是否存在用户eamil,我可以在使用firebug时看到发布的数据,但我一直遇到这样的错误:未定义索引:数据,我已经尽了很大努力,但尚未解决此问题。这是javascript:

$(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内容类型
在PHP端,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内容类型
在PHP端,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。没有问题:)编码愉快!