フロントエンド テクノロジーの発展に伴い、jQuery の使用率はますます高まっています。その中でもjQueryでajaxリクエストを利用してデータを取得するのが一般的ですが、実際の開発ではクロスドメインリクエストが発生した際に問題が発生するため、この記事ではクロスドメインリクエストのエラーを解決する方法を紹介します。
1. クロスドメイン リクエストとは
同じドメイン名の下で、ブラウザの ajax リクエストは自由にデータを送受信できます。ただし、異なるドメイン名では、ブラウザーでの ajax リクエストはセキュリティ ポリシーによって制限され、データを自由に送受信できなくなります。このようにして、クロスドメインリクエストが発生します。
2. クロスドメインリクエストエラーが発生する理由
セキュリティ上の理由から、ブラウザは同一オリジンポリシーを採用しています。同一生成元ポリシーは、異なるソースからのクライアント スクリプトが明示的な承認なしに相互にリソースを読み取ることができないことを意味します。同一生成元ポリシーでは、異なるソースからのクライアント スクリプトが相互に干渉することができないため、Web アプリケーションのセキュリティが確保されます。
相同性とは、具体的には、プロトコル、ドメイン名、ポート番号が完全に同じであることを意味します。
3. クロスドメイン リクエスト エラーを解決する方法
上記の背景知識があれば、クロスドメイン リクエスト エラーの問題を解決できます。
- 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 リクエストに対する応答を取得できないなど、いくつかの制限もあります。
- 応答ヘッダー 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 サイトの他の関連記事を参照してください。

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

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

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

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

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

keysinReactarecialforptimizingperformancebyididingineffictientListupdates.1)usekeystoidentifideidifyandtracklistelements.2)ArrayIndicesassyStopreventPerformanceSues.3)suoseStableidedifierslikeItem.idtomaincomentaindtateandiproveperift

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

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

ホットトピック









