ドメインをまたいでjsonデータを取得するjqueryのajaxとgetJsonの実装方法_jquery
多くの開発者は jquery を使用してフロントエンドとサーバーサイドでデータを操作しているため、フロントエンドで jquery を使用すればあらゆるサイトのデータを読み取ることができると考えがちです。最近開発をしていた際、他社のプロジェクトとデータを共有する必要があり、サーバーリソースをあまり占有しないことを考えて、サーバー経由でデータを転送するのではなく、HTMLで直接読み込むことにしました。その後、ブラウザ側でクロスドメインアクセスの問題が発生しました。
クロスドメインのセキュリティ制限はブラウザ側を指しますが、サーバー側にはクロスドメインのセキュリティ制限はありません。
現在、ブラウザ側のクロスドメイン アクセスには 2 つの一般的な方法が使用されています:
1. jQuery の ajax によるクロスドメイン これは実際には jsonp を使用して実装されます。
jsonp は英語の json with padding の略称です。これにより、スクリプト タグをサーバー側で生成してクライアントに返すことができます。つまり、JavaScript タグが動的に生成され、データは JavaScript コールバックを通じて読み取られます。
HTML ページ側のサンプル コード:
//まず jquery の js パッケージを紹介します
jQuery(document).ready(function(){
$.ajax({
type: "get", //jquey はポストクロスドメインをサポートしていません
async:false、
url: "http://api.taobao.com/apitools/ajax_props.do", //クロスドメインリクエスト URL
データタイプ: "jsonp"、
//jsonp コールバック関数名を取得するためにリクエスト ハンドラーに渡されるパラメータ名 (デフォルト: callback)
jsonp: "jsoncallback"、
//カスタマイズされた jsonp コールバック関数名、デフォルトは jQuery によって自動的に生成されるランダムな関数名です
jsonpCallback:"success_jsonpCallback",
//クロスドメインサーバー上の json データの取得に成功した後、このコールバック関数は動的に実行されます
成功: function(json){
アラート(json);
サーバー側のコードが重要なポイントです。私は当初、クライアントが jsonp を通じてクロスドメイン アクセスに直接アクセスできる限り、そうではなく、サーバー側のサポートが必要であると考えていました。
コードをコピー
コードは次のとおりです。
//callbackName の値は実際には次のようになります: success_jsonpCallback
文字列コールバック名 = (String)request.getAttribute("jsoncallback");
//json 文字列の単純なシミュレーション。実際には変換に Google の gson を使用できます。回数は文字列のスプライスによって行われます
//{"名前":"張三","年齢":28}
//「」記号をエスケープするためです
String jsonStr = "{"名前":"張三","年齢":28}";
//最終的に返されるデータは次のとおりです: success_jsonpCallback({"name":"Zhang San","age":28})
文字列 renderStr = callbackName "(" jsonStr ")";
response.setContentType("text/plain;charset=UTF-8");応答.getWriter().write(renderStr);
}
jsonp の原則:
まずクライアント側でコールバック (例: 'jsoncallback') を登録し、次にそのコールバック名 (例: success_jsonpCallback) をサーバー側の対応する処理関数に渡します。
サーバーはまず、クライアントに返す必要がある json データを生成します。次に、JavaScript 構文を使用して関数を生成します。関数名は、渡されたパラメーター (jsoncallback) (success_jsonpCallback) の値です。
最後に、json データがパラメーターとして関数に直接配置され、js 構文ドキュメントが生成され、クライアントに返されます。
クライアントのブラウザはスクリプト タグを解析し、サーバーから返されたデータをパラメータとして使用します。
クライアントによって事前定義されたコールバック関数を渡します (上記の例では jquery $.ajax() メソッドによってカプセル化されています)。成功: 関数 (json))。
実際には、データのクロスドメイン読み込みはスクリプトを動的に追加することで行われます。データを直接取得できないため、コールバック関数を使用する必要があります。
2. jquery の getJson を使用してドメイン間でデータを読み取る
実際、getJson メソッドの基本原理は、ajax が jsonp を使用する方法と同じです。
GetJson は、リモート データを取得し、json 形式で返すために jquery でよく使用されます。関数のプロトタイプは次のとおりです:
jQuery.getJSON(url,data,success(data,status,xhr))
参数 | 描述 |
---|---|
url | 必需。规定将请求发送的哪个 URL。 |
data | 可选。规定连同请求发送到服务器的数据。 |
success(data,status,xhr) |
可选。规定当请求成功时运行的函数。 额外的参数:
|
追加パラメータ:
- レスポンス - リクエストからの結果データが含まれます
- ステータス - リクエストのステータスが含まれます
- xhr - XMLHttpRequest オブジェクトが含まれます
コードは次のとおりです:
$.ajax({
url: url,
data: data,
成功: コールバック,
}); 🎜>本題に戻り、getJson を使用してドメイン間でデータを取得する方法を見てみましょう。
HTML ページのサンプル コード:
$ .getJSON( "http://api.taabao.com/apitools/ajax_props.do&jsoncallback=?",
関数 (データ) {
アラート(データ);
}
);
実行原理:
リクエストを送信するときは、コールバック関数名をサーバーに渡す必要があります。サーバーはコールバック関数名を取得し、クライアントがそれを呼び出せるように、戻りデータをパラメーターの形式でクライアントに返します。 。
そのため、リクエスト URL を送信するアドレスの後には、jsoncallback=? のようなパラメーターが続く必要があります。jquery は、? 番号を自動的に生成されたコールバック関数の名前に自動的に置き換えます。
最終的な実際のリクエストは次のとおりです:
http://api.taabao.com/apitools/ajax_props.do&jsoncallback=jsonp1322444422697そこで、ajax メソッドと比較したいと思います。つまり、コールバック関数の 1 つは自動生成された関数名で、もう 1 つは手動で指定した関数名です。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP 配列を JSON に変換するためのパフォーマンスの最適化方法には、JSON 拡張機能と json_encode() 関数の使用、文字エスケープを回避するためのバッファーの使用、およびサードパーティのエンコード結果の使用の検討が含まれます。 JSONエンコーディングライブラリ。

Jackson ライブラリのアノテーションは、JSON のシリアル化と逆シリアル化を制御します。 シリアル化: @JsonIgnore: プロパティを無視します @JsonProperty: 名前を指定します @JsonGetter: get メソッドを使用します @JsonSetter: set メソッドを使用します Deserialization: @JsonIgnoreProperties: プロパティ @ JsonProperty を無視します:名前を指定 @JsonCreator: コンストラクターを使用 @JsonDeserialize: カスタム ロジック

Ajax を使用して PHP メソッドから変数を取得することは、Web 開発では一般的なシナリオであり、Ajax を使用すると、データを更新せずにページを動的に取得できます。この記事では、Ajax を使用して PHP メソッドから変数を取得する方法と、具体的なコード例を紹介します。まず、Ajax リクエストを処理し、必要な変数を返すための PHP ファイルを作成する必要があります。以下は、単純な PHP ファイル getData.php のサンプル コードです。

PHP の深い理解: JSONUnicode を中国語に変換する実装方法 開発中、JSON データを処理する必要がある状況によく遭遇しますが、特に変換する必要がある場合、JSON 内の Unicode エンコードによっていくつかのシナリオで問題が発生します。 Unicode エンコードを漢字に変換する場合。 PHP では、この変換処理を実現するためのメソッドがいくつかありますが、以下では一般的なメソッドを紹介し、具体的なコード例を示します。まず、JSON の Un について理解しましょう

Ajax (非同期 JavaScript および XML) を使用すると、ページをリロードせずに動的コンテンツを追加できます。 PHP と Ajax を使用すると、製品リストを動的にロードできます。HTML はコンテナ要素を含むページを作成し、Ajax リクエストはロード後に要素にデータを追加します。 JavaScript は Ajax を使用して XMLHttpRequest を通じてサーバーにリクエストを送信し、サーバーから JSON 形式で商品データを取得します。 PHP は MySQL を使用してデータベースから製品データをクエリし、それを JSON 形式にエンコードします。 JavaScript は JSON データを解析し、ページ コンテナーに表示します。ボタンをクリックすると、製品リストをロードするための Ajax リクエストがトリガーされます。

PHP と Ajax を使用してオートコンプリート候補エンジンを構築します。 サーバー側スクリプト: Ajax リクエストを処理し、候補を返します (autocomplete.php)。クライアント スクリプト: Ajax リクエストを送信し、提案を表示します (autocomplete.js)。実際のケース: HTML ページにスクリプトを組み込み、検索入力要素の識別子を指定します。

PHP 配列は、 json_encode() 関数を使用して JSON 文字列に変換できます (例: $json=json_encode($array);)。逆に、 json_decode() 関数を使用して JSON から配列に変換できます ($array= json_decode($json);) 。その他のヒントには、深い変換の回避、カスタム オプションの指定、サードパーティ ライブラリの使用などがあります。

JSON (JavaScriptObjectNotation) は、Web アプリケーション間のデータ交換に一般的に使用される軽量のデータ交換形式です。 JSON データを処理するとき、Unicode でエンコードされた中国語の文字 (「u4e2du6587」など) が頻繁に発生するため、それらを読み取り可能な中国語の文字に変換する必要があります。 PHP では、いくつかの簡単なメソッドを通じてこの変換を実現できます。次に、JSONUnico を変換する方法を詳しく説明します。
