検索
ホームページウェブフロントエンドフロントエンドQ&Ajquery ajaxクロスドメインリクエストエラーレポート

フロントエンド テクノロジーの発展に伴い、jQuery の使用率はますます高まっています。その中でもjQueryでajaxリクエストを利用してデータを取得するのが一般的ですが、実際の開発ではクロスドメインリクエストが発生した際に問題が発生するため、この記事ではクロスドメインリクエストのエラーを解決する方法を紹介します。

1. クロスドメイン リクエストとは

同じドメイン名の下で、ブラウザの ajax リクエストは自由にデータを送受信できます。ただし、異なるドメイン名では、ブラウザーでの ajax リクエストはセキュリティ ポリシーによって制限され、データを自由に送受信できなくなります。このようにして、クロスドメインリクエストが発生します。

2. クロスドメインリクエストエラーが発生する理由

セキュリティ上の理由から、ブラウザは同一オリジンポリシーを採用しています。同一生成元ポリシーは、異なるソースからのクライアント スクリプトが明示的な承認なしに相互にリソースを読み取ることができないことを意味します。同一生成元ポリシーでは、異なるソースからのクライアント スクリプトが相互に干渉することができないため、Web アプリケーションのセキュリティが確保されます。

相同性とは、具体的には、プロトコル、ドメイン名、ポート番号が完全に同じであることを意味します。

3. クロスドメイン リクエスト エラーを解決する方法

上記の背景知識があれば、クロスドメイン リクエスト エラーの問題を解決できます。

  1. JSONP クロスドメイン リクエスト

JSONP (パディング付き JSON) は、クロスドメイン リクエストのソリューションです。その原理は、リクエストを行うときに、フロントエンドがスクリプトタグを動的に作成してコールバック関数名を渡し、サーバーから返されたデータがコールバック関数で実行されるというものです。

具体的な手順は次のとおりです。

1) フロントエンド コード

$.ajax({
    url:'/api/get-data',
    dataType:'jsonp',
    jsonp:'callback',
    success:function (data) {
        console.log(data);
    }
});

説明:

url: 要求されたインターフェイス アドレス

dataType: データ型、ここでは jsonp

jsonp: クライアント要求関数、関数名はコールバック関数の名前として使用されます

success: 要求成功

2) バックエンドコード

(1) 戻り値の前にリクエスト パラメータのコールバックを追加します。

{
'name':'Tom',
'age':23,
'性別' :'男性',
'callbackCode':1
}

(2) 結果を返します

callbacks.callbackCode({"name":"トム","年齢" :23,"性別":"男"});

このうち、callbackCodeはフロントエンドが設定するリクエストメソッド名です。

別の例:

(1) リクエスト パラメータのコールバックが戻り値の前に追加されます

{
'code':'0',
' data' :{

   'name':'Tom',
   'age':23,
   'sex':'男',

},
'message': 'リクエストは成功しました。 ',
'callbackCode':1
}

(2) バックエンドは、callbackCode パラメーターを介してコールバック関数を結合します。

callbacks.callbackCode({"コード":"0","データ":{"名前":"トム","年齢":23,"性別":"男性"},"メッセージ" :"リクエストが成功しました!"});

上記の手順を通じて、JSONP を使用してクロスドメイン リクエストを行うことができます。ただし、JSONP には、GET リクエストのみをサポートし、POST リクエストに対する応答を取得できないなど、いくつかの制限もあります。

  1. 応答ヘッダー Access-Control-Allow-Origin を追加します

もう 1 つの方法は、バックエンド インターフェイスで設定し、応答ヘッダーに Access-Control- を追加することです。 「Allow-Origin」フィールドは、要求元のブラウザーにこのクロスオリジン要求を許可するように指示します。

コード例:

@RequestMapping("/api/get-data")
@RestController
public class GetDataController {

@GetMapping
public String getData(HttpServletRequest request) {
    String callback = request.getParameter("callback");

    //模拟后端返回数据
    String json = "{"name":"Tom","age":23,"sex":"男"}";

    //跨域请求响应头设置
    String result = callback + "(" + json + ")";
    return result;
}

}

その中で、メソッドは @GetMapping アノテーションを介して /api/get-data インターフェイスにマップされ、その後リクエスト パラメーターのコールバックが取得され、バックエンドがデータを返すようにシミュレートされ、最後に json データが結果変数を介したコールバック関数の形式。

上記の 2 つの方法により、クロスドメイン リクエスト エラーの問題を解決できます。

概要:

この記事の導入部を通じて、クロスドメイン リクエストとは何か、クロスドメイン リクエスト エラーが発生する理由、およびクロスドメイン リクエスト エラーを解決する方法を理解しました。その中で、主に JSONP クロスドメインリクエストとレスポンスヘッダー Access-Control-Allow-Origin の追加の 2 つの方法を紹介しました。もちろん、さまざまなシナリオで問題を解決するためにさまざまな方法を選択することで、真のニーズを満たすことができます。

以上がjquery ajaxクロスドメインリクエストエラーレポートの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

raceslimitationsinclude:1)asteeplearningcurveduetoitsvastecosystem、2)seochallengeswithsclient-siderEndering、3)潜在的なパフォーマンスのinlargeapplications、4)complenstatemanagementasappsgrow、and5)suneedtokeepupwithovolution

Reactの学習曲線:新しい開発者にとっての課題Reactの学習曲線:新しい開発者にとっての課題May 02, 2025 am 12:24 AM

ReactisChallengingを使用して、SteepLearNdParadigMshiftOconpontenAchitecture.1)startisofficialdocumentation forasolidfoundation.2)relondingjsxandjavascriptwithinit.3)LearntousefunctionalcompotontiTateを理解してください

反応の動的リストの安定したユニークなキーを生成する反応の動的リストの安定したユニークなキーを生成するMay 02, 2025 am 12:22 AM

coreChallengeingEneratingは、duniqueys consinistinsidentifientiversre-renderseforeffiencedomupdates.1)aseenaturalKeysisisisisisisisedisederiableiableiaibuniqueandStable.2)denatekeysBaseTheBasedOnMultipreattributive.2)を無効にすることを非難することを解決します

JavaScriptの疲労:Reactとそのツールで最新の状態を維持しますJavaScriptの疲労:Reactとそのツールで最新の状態を維持しますMay 02, 2025 am 12:19 AM

javascriptfatigueinReactismainageable with rikeislikedivedingingindininginginformationscors.1)whatyouneedwhenyouneedit、focusingonprojectrelevance.2)

UseState()フックを使用するコンポーネントをテストしますUseState()フックを使用するコンポーネントをテストしますMay 02, 2025 am 12:13 AM

ESTESTROACTCOMPONENTSINGTHESESTATEHOOK、USEJESTANDREACTINTINGLIBRARYTOSIMULATE INTERACTIONSIONDANDVERIFYISTAMESISINTHEUI.1)RENDERTHECONCENTANDCHECKECHINITATA.2)SimulateUserIractionSionsionsionsionsionsionslikeClickSorformSubmissions.3)

Reactのキー:パフォーマンスの最適化技術への深い飛び込みReactのキー:パフォーマンスの最適化技術への深い飛び込みMay 01, 2025 am 12:25 AM

keysinReactarecialforptimizingperformancebyididingineffictientListupdates.1)usekeystoidentifideidifyandtracklistelements.2)ArrayIndi​​cesassyStopreventPerformanceSues.3)suoseStableidedifierslikeItem.idtomaincomentaindtateandiproveperift

Reactのキーとは何ですか?Reactのキーとは何ですか?May 01, 2025 am 12:25 AM

ReactKeySareUniqueIdentifiersiersiderSuredStrovereconconiniationEfficiency.1)theyctrackChangesinListitems、2)sultanduniqueidentifiersiirsiTeemidssisssississmendを使用して、3)ArrayIndi​​cesAssayStopReventisSuseSUSEORINGを回避します

反応におけるユニークな鍵の重要性:一般的な落とし穴を避ける反応におけるユニークな鍵の重要性:一般的な落とし穴を避けるMay 01, 2025 am 12:19 AM

sinqueysarecrucialinReactforoptimizing andMaintainingcomponentStateIntegrity.1)useanaturaluniqueidentifierfromyourdataifaibable.2)ifnonaturalidentifierexists、発電済みのKeyusingingingingalibrarylikuuid.3)

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 中国語版

SublimeText3 中国語版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。