ajxs跨域 php_php设置header头允许ajax跨域请求
在做項目的時候,我們有時候希望能夠可以跨域進行請求,但是ajax訪問php接口的時候,通常會報一個錯誤:
Failed to load 你的網址/test.php: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access.
這種情況解決起來也非常的簡單,我們只需要給php的文件加一個header頭就可以了。
header("Access-Control-Allow-Origin: *"); // 表示允許任何域名進行訪問
當然我們還可以進行域名的限定,只允許特定的域名進行訪問
header("Access-Control-Allow-Origin:http://dedecms.sj.com");
另外我們還可以設置,允許的請求是get、post等
// 響應類型
header("Access-Control-Allow-Methods: POST, GET, OPTIONS, PUT, DELETE");
// 響應頭設置
header('Access-Control-Allow-Headers:x-requested-with,content-type');
補充:
何為跨域請求呢?大致可分為如下幾種情況
A.abc.com 發起一個到 abc.com/B 的ajax請求,也會有跨域的問題。之所以會有跨域問題,實則是因為www.abc.com其實同A.abc.com一樣,也是一個二級域名,而非一級域名(一級域名是http://abc.com)
對于是否允許跨域,更詳細的說明可以看下表:
URL
說明
是否允許通信
http://www.a.com/a.js
http://www.a.com/b.js
同一域名下
允許
http://www.a.com/lab/a.js
http://www.a.com/script/b.js
同一域名下不同文件夾
允許
http://www.a.com:8000/a.js
http://www.a.com/b.js
同一域名,不同端口
不允許
http://www.a.com/a.js
https://www.a.com/b.js
同一域名,不同協議
不允許
http://www.a.com/a.js
http://170.32.82.74/b.js
域名和域名對應ip
不允許
http://www.a.com/a.js
http://script.a.com/b.js
同一域名,不同二級域名
不允許
http://www.a.com/a.js
http://a.com/b.js
二級域名和一級域名
不允許(cookie這種情況下也不允許訪問)
http://www.b.com/a.js
http://www.a.com/b.js
不同域名
總結
以上是生活随笔為你收集整理的ajxs跨域 php_php设置header头允许ajax跨域请求的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: if js 判断成绩等级_javascr
- 下一篇: 优信拍集团php面试题_【优信拍PHP高