Rumah > pembangunan bahagian belakang > tutorial php > Bagaimanakah JSONP Menyelesaikan Masalah Pengambilan Data Silang Asal?

Bagaimanakah JSONP Menyelesaikan Masalah Pengambilan Data Silang Asal?

Patricia Arquette
Lepaskan: 2024-12-07 20:21:14
asal
325 orang telah melayarinya

How Does JSONP Solve Cross-Origin Data Retrieval Problems?

JSONP: Pengambilan Data Silang Asal Dipermudahkan

Apabila berurusan dengan permintaan web silang asal, dasar asal yang sama boleh menimbulkan cabaran . JSONP (JSON dengan Padding) muncul sebagai penyelesaian untuk menangani isu ini. Berikut ialah penjelasan langkah demi langkah tentang cara melaksanakan permintaan jQuery, PHP dan JSONP asas untuk mendapatkan semula data daripada domain yang berbeza:

Permintaan jQuery

$.getJSON('http://www.write-about-property.com/jsonp.php?callback=?', { firstname: 'Jeff' }, function(res) {
  alert('Your name is ' + res.fullname);
});
Salin selepas log masuk

Respon PHP

<?php
  $fname = $_GET['firstname'];
  if ($fname == 'Jeff') {
    echo $_GET['callback'] . '(' . "{'fullname' : 'Jeff Hansen'}" . ')';
  }
?>
Salin selepas log masuk

Kunci Pengubahsuaian:

  • ?panggilan balik=?: Dalam JSONP, pelayan menyertakan fungsi panggil balik dalam respons. ?panggilan balik=? membolehkan penyemak imbas menyediakan fungsi panggil balik yang dijana secara dinamik untuk pelayan.
  • $_GET['callback'] . '(': Pelayan menggunakan JavaScript untuk memanggil fungsi panggil balik yang disediakan oleh penyemak imbas.
  • res.nama penuh: Kod JavaScript mengakses JSON yang dikembalikan daripada pelayan dan memaparkan nilai 'nama penuh'.

HTML dalam Respons

Ya, anda boleh menyimpan HTML dalam hasilnya dan ia akan dikembalikan sebagai rentetan Kod JavaScript kemudiannya akan mengendalikan HTML mengikut kesesuaian.

Contoh Penggunaan.

Contoh ini mendapatkan semula nama penuh 'Jeff' daripada skrip PHP yang terletak di 'http://www.write-about-property.com/jsonp.php' Jika nama itu sepadan dengan 'Jeff', nama penuh 'Jeff Hansen' dikembalikan.

Atas ialah kandungan terperinci Bagaimanakah JSONP Menyelesaikan Masalah Pengambilan Data Silang Asal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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