Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Menyelesaikan Ralat \'Origin is Not Allowed by Access-Control-Allow-Origin\' dalam Permintaan AJAX Cross-Origin?

Bagaimana untuk Menyelesaikan Ralat \'Origin is Not Allowed by Access-Control-Allow-Origin\' dalam Permintaan AJAX Cross-Origin?

Mary-Kate Olsen
Lepaskan: 2024-10-19 11:30:01
asal
876 orang telah melayarinya

How to Resolve

Masalah: "Origin is Not Allowed by Access-Control-Allow-Origin"

Apabila melakukan permintaan AJAX silang asal menggunakan JavaScript, anda mungkin menghadapi ralat berikut :

Origin http://localhost:8080 is not allowed by Access-Control-Allow-Origin
Salin selepas log masuk

Ralat ini berlaku disebabkan oleh "Dasar Asal yang Sama", iaitu ciri keselamatan yang dilaksanakan dalam penyemak imbas untuk menghalang skrip hasad daripada mengakses data daripada domain lain.

Punca

"Dasar Asal Sama" mengehadkan permintaan AJAX kepada domain, protokol dan port yang sama sebagai halaman asal. Jika JavaScript anda dihoskan pada domain, protokol atau port yang berbeza daripada pelayan yang anda cuba akses, permintaan itu akan disekat.

Penyelesaian: JSONP

Untuk memintas "Same Dasar Asal," satu penyelesaian biasa ialah menggunakan JSONP (JSON dengan Padding). JSONP membenarkan anda membuat permintaan silang asal dengan membungkus respons dalam fungsi panggil balik yang ditakrifkan dalam JavaScript anda sendiri.

Begini cara JSONP berfungsi:

  1. Tentukan fungsi panggil balik dalam JavaScript anda.
  2. Hantar permintaan AJAX dengan URL yang berakhir dengan ?callback={callback_function_name}.
  3. Pelayan bertindak balas dengan data JSON yang dibungkus dalam fungsi panggil balik.
  4. The fungsi panggil balik dilaksanakan, menerima data respons.

Contoh

Untuk menyelesaikan ralat dalam kod yang diberikan, yang cuba membuat permintaan POST silang asal kepada YouTube, anda boleh menggunakan JSONP seperti berikut:

<code class="javascript">var script = document.createElement('script');
script.src = "http://gdata.youtube.com/action/GetUploadToken?callback=callbackFunction";
document.head.appendChild(script);

function callbackFunction(data) {
    // Use the response data
}</code>
Salin selepas log masuk

Dalam contoh ini, callbackFunction ialah fungsi yang ditakrifkan dalam JavaScript anda sendiri, yang akan menerima respons daripada YouTube sebagai hujah.

Nota : Adalah penting untuk memastikan pelayan yang anda hantar permintaan menyokong JSONP dan anda menggunakan nama fungsi panggil balik yang betul dalam URL.

Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan Ralat \'Origin is Not Allowed by Access-Control-Allow-Origin\' dalam Permintaan AJAX Cross-Origin?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan