Rumah hujung hadapan web Soal Jawab bahagian hadapan jquery ajax pelaporan ralat permintaan merentas domain

jquery ajax pelaporan ralat permintaan merentas domain

May 18, 2023 pm 12:38 PM

Dengan perkembangan teknologi hadapan, penggunaan jQuery semakin tinggi dan lebih tinggi. Antaranya, adalah sangat biasa untuk menggunakan permintaan ajax dalam jQuery untuk mendapatkan data Walau bagaimanapun, dalam pembangunan sebenar, beberapa masalah akan berlaku apabila menghadapi permintaan merentas domain.

1. Apakah permintaan merentas domain?

Di bawah nama domain yang sama, permintaan ajax penyemak imbas boleh menghantar dan menerima data secara bebas. Walau bagaimanapun, di bawah nama domain yang berbeza, permintaan ajax dalam penyemak imbas dihadkan oleh dasar keselamatan, dan data tidak boleh dihantar dan diterima sesuka hati. Dengan cara ini, permintaan merentas domain berlaku.

2. Mengapa ralat permintaan merentas domain berlaku

Atas sebab keselamatan, penyemak imbas menggunakan dasar asal yang sama. Dasar asal yang sama bermakna skrip klien daripada sumber yang berbeza tidak boleh membaca sumber satu sama lain tanpa kebenaran yang jelas. Di bawah dasar asal yang sama, skrip klien daripada sumber yang berbeza tidak boleh mengganggu satu sama lain, sekali gus memastikan keselamatan aplikasi web.

Secara khusus, homologi bermaksud protokol, nama domain dan nombor port adalah sama sepenuhnya.

3. Bagaimana untuk menyelesaikan ralat permintaan merentas domain

Dengan pengetahuan latar belakang di atas, kami boleh menyelesaikan masalah ini untuk ralat permintaan merentas domain.

  1. Permintaan merentas domain JSONP

JSONP (JSON dengan Padding) ialah penyelesaian untuk permintaan merentas domain. Prinsipnya ialah apabila membuat permintaan, bahagian hadapan secara dinamik mencipta teg skrip dan menghantar nama fungsi panggil balik, dan data yang dikembalikan oleh pelayan akan dilaksanakan dalam fungsi panggil balik.

Langkah khusus adalah seperti berikut:

1) Kod bahagian hadapan

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

Penerangan:

url: alamat antara muka yang diminta

dataType: Jenis data, berikut adalah jsonp

jsonp: fungsi permintaan pelanggan, nama fungsi akan digunakan sebagai nama fungsi panggil balik

kejayaan: permintaan berjaya

2) Kod hujung belakang

(1) Tambah panggil balik parameter permintaan sebelum nilai pulangan

{
'nama':'Tom',
'umur':23,
'seks' :'Lelaki',
'Kod panggilan balik':1
}

(2) Hasil pengembalian

callbacks.callbackCode({"name":"Tom ","umur" :23,"seks":"lelaki"});

Antaranya, Kod panggil balik ialah nama kaedah permintaan yang ditetapkan oleh hujung hadapan.

Contoh lain:

(1) Panggilan balik parameter permintaan ditambahkan sebelum nilai pulangan

{
'kod':'0',
' data' :{

   'name':'Tom',
   'age':23,
   'sex':'男',
Salin selepas log masuk

},
'mesej': 'Permintaan berjaya! ',
'Kod panggil balik':1
}

(2) Bahagian belakang menyambung fungsi panggil balik melalui parameter Kod panggil balik.

callbacks.callbackCode({"code":"0","data":{"name":"Tom","age":23,"jantina":"lelaki"},"message" :"Permintaan berjaya!"});

Melalui langkah di atas, kami boleh menggunakan JSONP untuk membuat permintaan merentas domain. Walau bagaimanapun, JSONP juga mempunyai beberapa had, seperti hanya menyokong permintaan GET dan tidak dapat mendapatkan respons kepada permintaan POST.

  1. Tambahkan pengepala respons Access-Control-Allow-Origin

Cara lain ialah menetapkannya pada antara muka hujung belakang dan tambah Access-Control- dalam pengepala respons. Medan Allow-Origin memberitahu penyemak imbas yang meminta untuk membenarkan permintaan merentas domain ini.

Contoh kod:

@RequestMapping("/api/get-data")
@RestController
kelas awam 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;
}
Salin selepas log masuk

}

Antaranya, kaedah dipetakan ke antara muka /api/get-data melalui anotasi @GetMapping, kemudian parameter permintaan panggil balik diperoleh, hujung belakang disimulasikan untuk mengembalikan data, dan akhirnya data json dikembalikan dalam bentuk fungsi panggil balik melalui pembolehubah hasil.

Melalui dua kaedah di atas, kami boleh menyelesaikan masalah ralat permintaan merentas domain.

Ringkasan:

Melalui pengenalan artikel ini, kami memahami apa itu permintaan merentas domain, sebab ralat permintaan merentas domain berlaku dan cara menyelesaikan ralat permintaan merentas domain. Antaranya, kami memperkenalkan dua kaedah terutamanya: permintaan merentas domain JSONP dan menambah pengepala respons Access-Control-Allow-Origin. Sudah tentu, memilih kaedah yang berbeza untuk menyelesaikan masalah dalam senario yang berbeza benar-benar dapat memenuhi keperluan.

Atas ialah kandungan terperinci jquery ajax pelaporan ralat permintaan merentas domain. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China 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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apa itu useeffect? Bagaimana anda menggunakannya untuk melakukan kesan sampingan? Apa itu useeffect? Bagaimana anda menggunakannya untuk melakukan kesan sampingan? Mar 19, 2025 pm 03:58 PM

Artikel ini membincangkan useeffect dalam React, cangkuk untuk menguruskan kesan sampingan seperti pengambilan data dan manipulasi DOM dalam komponen berfungsi. Ia menerangkan penggunaan, kesan sampingan yang biasa, dan pembersihan untuk mencegah masalah seperti kebocoran memori.

Bagaimanakah algoritma Rekonsiliasi React berfungsi? Bagaimanakah algoritma Rekonsiliasi React berfungsi? Mar 18, 2025 pm 01:58 PM

Artikel ini menerangkan algoritma perdamaian React, yang dengan cekap mengemas kini DOM dengan membandingkan pokok DOM maya. Ia membincangkan manfaat prestasi, teknik pengoptimuman, dan kesan terhadap pengalaman pengguna. Kira -kira: 159

Apakah fungsi pesanan yang lebih tinggi dalam JavaScript, dan bagaimana mereka boleh digunakan untuk menulis lebih banyak kod ringkas dan boleh diguna semula? Apakah fungsi pesanan yang lebih tinggi dalam JavaScript, dan bagaimana mereka boleh digunakan untuk menulis lebih banyak kod ringkas dan boleh diguna semula? Mar 18, 2025 pm 01:44 PM

Fungsi pesanan yang lebih tinggi dalam JavaScript meningkatkan ketabahan kod, kebolehgunaan semula, modulariti, dan prestasi melalui abstraksi, corak umum, dan teknik pengoptimuman.

Bagaimanakah kari bekerja di JavaScript, dan apakah faedahnya? Bagaimanakah kari bekerja di JavaScript, dan apakah faedahnya? Mar 18, 2025 pm 01:45 PM

Artikel ini membincangkan kari dalam JavaScript, teknik yang mengubah fungsi multi-argumen ke dalam urutan fungsi argumen tunggal. Ia meneroka pelaksanaan kari, faedah seperti aplikasi separa, dan kegunaan praktikal, meningkatkan kod baca

Bagaimana anda menyambungkan komponen React ke kedai Redux menggunakan Connect ()? Bagaimana anda menyambungkan komponen React ke kedai Redux menggunakan Connect ()? Mar 21, 2025 pm 06:23 PM

Artikel membincangkan penyambungan komponen reaksi ke kedai redux menggunakan Connect (), menerangkan MapStateToprops, MapdispatchToprops, dan kesan prestasi.

Apakah useContext? Bagaimana anda menggunakannya untuk berkongsi keadaan antara komponen? Apakah useContext? Bagaimana anda menggunakannya untuk berkongsi keadaan antara komponen? Mar 19, 2025 pm 03:59 PM

Artikel ini menerangkan USEContext dalam React, yang memudahkan pengurusan negara dengan mengelakkan penggerudian prop. Ia membincangkan faedah seperti keadaan terpusat dan penambahbaikan prestasi melalui pengurangan semula yang dikurangkan.

Bagaimana anda mengelakkan tingkah laku lalai di pengendali acara? Bagaimana anda mengelakkan tingkah laku lalai di pengendali acara? Mar 19, 2025 pm 04:10 PM

Artikel membincangkan menghalang tingkah laku lalai dalam pengendali acara menggunakan kaedah pencegahanDefault (), faedahnya seperti pengalaman pengguna yang dipertingkatkan, dan isu -isu yang berpotensi seperti kebimbangan aksesibiliti.

Bagaimana anda melaksanakan cangkuk tersuai dalam React? Bagaimana anda melaksanakan cangkuk tersuai dalam React? Mar 18, 2025 pm 02:00 PM

Artikel ini membincangkan pelaksanaan cangkuk tersuai dalam React, memberi tumpuan kepada penciptaan, amalan terbaik, manfaat prestasi, dan perangkap umum untuk dielakkan.

See all articles