Cara Menghindari Sekatan Access-Control-Allow-Origin
Menghadapi ralat Access-Control-Allow-Origin semasa panggilan AJAX boleh mengecewakan, terutamanya apabila anda perlu mendapatkan semula data daripada pelayan anda sendiri. Walaupun anda mungkin tidak mempunyai akses kepada kod sumber platform, terdapat penyelesaian mudah untuk memintas sekatan ini.
Penyelesaian: Menambah Pengepala Kawalan Akses
Untuk mengelakkan silang -permintaan asal, pelayan yang mengehos API atau data yang anda cuba dapatkan daripada menetapkan pengepala Access-Control-Allow-Origin. Untuk memintas ini, tambahkan kod berikut pada bahagian atas skrip atau halaman yang memulakan panggilan AJAX (cth., retrieve.php):
header('Access-Control-Allow-Origin: *');
Dengan menetapkan pengepala ini, anda melumpuhkan CORS dengan berkesan (Cross- Perkongsian Sumber Asal) perlindungan dan membenarkan semua domain mengakses sumber anda. Ambil perhatian bahawa ini boleh menjadi risiko keselamatan, jadi anda dinasihatkan untuk mengunci asal ke tapak web tertentu. Contohnya:
header('Access-Control-Allow-Origin: https://www.example.com');
Tetapan ini hanya akan membenarkan permintaan silang asal daripada domain yang ditentukan.
JSON Equivalent
JSON tidak asli menyokong memintas sekatan CORS. Walau bagaimanapun, anda boleh menggunakan teknik JSONP (JSON dengan Padding) untuk mencapai kesan yang sama. Ini melibatkan membungkus respons JSON dalam panggilan fungsi, yang membolehkan penyemak imbas melaksanakannya sebagai JavaScript dan memintas sekatan CORS.
Sumber Tambahan
Untuk pemahaman yang lebih mendalam tentang Akses -Control-Allow-Origin dan CORS, rujuk sumber berikut:
Atas ialah kandungan terperinci Bagaimana untuk Memintas Sekatan Akses-Kawalan-Benarkan-Asal untuk Panggilan AJAX?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!