PHP ajax跨域问题最佳解决方案
一、本文通過設置Access-Control-Allow-Origin來實現跨域。
例如:客戶端的域名是client.runoob.com,而請求的域名是server.runoob.com。
如果直接使用ajax訪問,會有以下錯誤:
XMLHttpRequest?cannot load http://server.runoob.com/server.php. No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://client.runoob.com' is therefore not allowed access.
1、允許單個域名訪問
指定某域名(http://client.runoob.com)跨域訪問,則只需在http://server.runoob.com/server.php文件頭部添加如下代碼:header('Access-Control-Allow-Origin:http://client.runoob.com');
2、允許多個域名訪問
指定多個域名(http://client1.runoob.com、http://client2.runoob.com等)跨域訪問,則只需在http://server.runoob.com/server.php文件頭部添加如下代碼: $origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : ''; $allow_origin = array( 'http://client1.runoob.com', 'http://client2.runoob.com' ); if(in_array($origin, $allow_origin)){ header('Access-Control-Allow-Origin:'.$origin); }3、允許所有域名訪問
允許所有域名訪問則只需在http://server.runoob.com/server.php文件頭部添加如下代碼:header('Access-Control-Allow-Origin:*');
?
二、Ajax發起JSONP跨域請求
我們通過jQuery的JSONP方式可以實現跨域ajax請求,服務端php也需要做出相應的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和返回數據。
示例:前端頁面發起JSONP請求:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | $.ajax({ ??type: "get", ??data: "random="+Math.random(), ??url: "http://demo.jb51.net/phpajax/jsonp.php", ??dataType: "jsonp", ??jsonp: "callback", ??success: function(data) { ???console.log(data); ??}, ??error: function() { ???console.log('Request Error.'); ??} }); |
?
?
?
?
?
?
?
我們會發現,ajax請求參數中有 dataType: "jsonp" 和 jsonp: "callback" ,這個就表明了我要請求的是jsonp,并且會有回調callback返回。當然,我們也可以自定義回調函數,如 jsonpCallback:"success_jsonpCallback"
還可以簡單的寫成:
| 1 2 3 4 5 | jQuery.getJSON('http://demo.jb51.net/phpajax/jsonp.php?callback=?",{ ?random: Math.random() }, function(data){ ?console.log(data); }); |
?
?
?
php后端服務代碼可以這樣寫(注意輸出返回的格式):
| 1 2 3 4 5 | $data = array( ??'rand' => $_GET['random'], ??'msg' => 'Success' ); echo $_GET['callback'].'('.json_encode($data).')'; |
轉載于:https://www.cnblogs.com/missphp/p/9253877.html
總結
以上是生活随笔為你收集整理的PHP ajax跨域问题最佳解决方案的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: js判断对象数组中是否存在某个对象
- 下一篇: 编译安装PHP-7.2.8