ホームページ  >  記事  >  バックエンド開発  >  Ajaxは、return phpインターフェースを呼び出してjsonデータを返すメソッドを実装します。

Ajaxは、return phpインターフェースを呼び出してjsonデータを返すメソッドを実装します。

墨辰丷
墨辰丷オリジナル
2018-05-23 09:33:503167ブラウズ

この記事では、return php インターフェースを呼び出して json データを返す ajax の実装方法を主に紹介します。興味のある方は参考にしていただければ幸いです。

phpコードは次のとおりです:

<?php

  header(&#39;Content-Type: application/json&#39;);
  header(&#39;Content-Type: text/html;charset=utf-8&#39;);

  $email = $_GET[&#39;email&#39;];

  $user = [];

  $conn = @mysql_connect("localhost","Test","123456") or die("Failed in connecting database");
  mysql_select_db("Test",$conn);
  mysql_query("set names &#39;UTF-8&#39;");
  $query = "select * from UserInformation where email = &#39;".$email."&#39;";
  $result = mysql_query($query);
  if (null == ($row = mysql_fetch_array($result))) {
    echo $_GET[&#39;callback&#39;]."(no such user)";
  } else {
    $user[&#39;email&#39;] = $email;
    $user[&#39;nickname&#39;] = $row[&#39;nickname&#39;];
    $user[&#39;portrait&#39;] = $row[&#39;portrait&#39;];
    echo $_GET[&#39;callback&#39;]."(".json_encode($user).")";
  }

?>

jsコードは次のとおりです:

<script>
    $.ajax({
      url: "http://test.localhost/UserInterfaceForChatroom/UserInformation.php?email=pshuyue@gmail.com",
      type: "GET",
      dataType: &#39;jsonp&#39;,
      //      crossDomain: true,
      success: function (result) {
        //        data = $.parseJSON(result);
        //        alert(data.nickname);
        alert(result.nickname);
      }
    });
  </script>

2つの問題が発生しました:

1 、いいえ。質問:


Uncaught SyntaxError: Unexpected token :

解決策は次のとおりです:

これは私に起こったばかりで、その理由は上記のいずれでもありませんでした。 jQuery コマンド getJSON を使用し、JSONP を使用するために callback=? を追加し (クロスドメインに移動する必要があるため)、JSON コード {"foo":"bar"} を返してエラーが発生しました。

これは、 jQuery17209314005577471107_1335958194322({"foo":"bar"}) のようなコールバック データを含めるべきでした

これを実現するために使用した PHP コードは次のとおりです。JSON (コールバックなし) を使用するとパフォーマンスが低下します:

$ret[&#39;foo&#39;] = "bar";
finish();

function finish() {
  header("content-type:application/json");
  if ($_GET[&#39;callback&#39;]) {
    print $_GET[&#39;callback&#39;]."(";
  }
  print json_encode($GLOBALS[&#39;ret&#39;]);
  if ($_GET[&#39;callback&#39;]) {
    print ")";
  }
  exit; 
}

将来誰かの役に立つことを願っています。

2. 2 番目の質問:

json データを解析します。上記の JavaScript からわかるように、私は jquery.parseJSON() メソッドを使用しませんでしたが、これらのメソッドを使用し始めましたが、エラー

VM219:1 Uncaught SyntaxError: Unexpected token o in JSON at location 1 が常に報告されました。その後、 jquery.parseJSON() メソッドを使用しなくても、すべて正常に動作します。なぜだか分からない。

関連する推奨事項:

php_phpの基本におけるini設定原則の詳細な説明

php形式のJSON関数のサンプルコード_phpのスキル

php_phpの基本における{}中括弧の意味

以上がAjaxは、return phpインターフェースを呼び出してjsonデータを返すメソッドを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。