1

テキストボックスのデータを 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($_POST['data']))」を追加しましたが、どうやら設定されていません。

4

2 に答える 2

2

$_POSTキー/値形式の URL エンコード データ用です。異なる生のJSONを送信しています。$HTTP_RAW_POST_DATA現在の Javascript では、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!");
                }
            }
        });

変更点:

  • data変数を Javascript オブジェクト (JSON ではない) に
  • オブジェクトの JSON エンコード バージョンである 1 つの入力 (データ) を使用して、フォーム エンコードされた POST データとして送信しdataます。
  • JSON コンテンツ タイプを削除しました

PHP 側では、JSON がオブジェクトにデコードされるため、次を使用します。

$data = $_POST['data'];
$email = json_decode($data);
$Email = $Email->Email;

json_decode()配列構文を使用できますが、 の 2 番目の引数をto に設定した場合に限りますtruejson_decode()引数として渡された変数を更新しないため、戻り値を取得する必要があります。

于 2013-10-19T16:31:50.577 に答える
-1

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

そして、にアクセスすることで、サーバー側の電子メール値を使用できます$_POST['Email']

于 2013-10-19T16:28:41.120 に答える