ホームページ > バックエンド開発 > PHPチュートリアル > JavaScript でクロスドメインリクエスト用の JSONP コールバックを作成するにはどうすればよいですか?

JavaScript でクロスドメインリクエスト用の JSONP コールバックを作成するにはどうすればよいですか?

Susan Sarandon
リリース: 2024-10-22 20:54:00
オリジナル
840 人が閲覧しました

How to Create JSONP Callbacks in JavaScript for Cross-Domain Requests?

JavaScript での JSONP コールバックの作成

クロスドメインリクエストは、JavaScript 開発において課題となる可能性があります。ただし、JSONP (パディング付き JSON) は、この問題の解決策を提供します。

JSONP 用に JSON API を変更する

JSON API で JSONP 機能を有効にするには、次の手順に従います。以下の簡単な手順:

  1. GET リクエストの「コールバック」パラメータを受け入れます:

    if(array_key_exists('callback', $_GET)){
    ログイン後にコピー
  2. データの周りにコールバック関数をラップします:

    $callback.'('.$data.');';
    ログイン後にコピー

例として PHP を使用して、以下のコードは次の手順を示します:

<code class="php"><?php

$data = '{}'; // json string

if(array_key_exists('callback', $_GET)){

    header('Content-Type: text/javascript; charset=utf8');
    header('Access-Control-Allow-Origin: http://www.example.com/');
    header('Access-Control-Max-Age: 3628800');
    header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE');

    $callback = $_GET['callback'];
    echo $callback.'('.$data.');';

}else{
    // normal JSON string
    header('Content-Type: application/json; charset=utf8');

    echo $data;
}
?></code>
ログイン後にコピー

JSONP サービスの使用

JSONP サービスを利用するには、HTML スクリプト タグを使用できます:

<code class="html"><script>
    function receiver(data){
        console.log(data);
    }
</script>

<script src="data-service.php?callback=receiver"></script></code>
ログイン後にコピー

以上がJavaScript でクロスドメインリクエスト用の JSONP コールバックを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート