這篇文章介紹的內容是關於PHP的跨域問題,現在分享給大家,有需要的朋友可以參考一下
先說一個最簡單的例子吧
先上服務端的代碼
public function kuayu(){ header("Access-Control-Allow-Origin: http://baidu.com"); //說明是允許百度訪問你的伺服器 return json(['status'=>0,'msg'=>1231]);}
Access-Control-Allow-Origin:加上你請求該伺服器的網域名稱
如果要允許所有的伺服器訪問的話就只需要一個*,例如Access-Control-Allow-Origin:*
最後上用戶端的代碼
$.ajax({ url:'http://xxx.com/kuayu',這裡填寫你所訪問的連結 async:false, success:function(res){ console.log(res); }})
最後就完成了簡單的跨域請求
下面再簡單說一下jsonp跨域吧(由於博主理論知識不紮實,只能貼一下代碼了,哈哈)
先上服務端的代碼
public function kuayu(){ return input('get.callback')."(".json_encode(['status'=>0,'msg'=>1231]).")";}
用戶端的代碼
$.ajax({ url:'http://www.xx.cn/kuayu', dataType:'jsonp',固定寫法 jsonp:'callback',固定寫法 success:function(res){ console.log(res); }})
這個有個坑,就是服務端返回資料的格式一定要是如下
jQuery111307920822086038766_1523501176244({"status":0,"msg":1231})
前面的那一大串是系統產生的,也可以是自訂的
所以服務端的返回資料一定要是 $_GET['callback'].(資料) 這樣的格式哦