ajxs跨域 php_php设置header头允许ajax跨域请求
在做項目的時候,我們有時候希望能夠可以跨域進行請求,但是ajax訪問php接口的時候,通常會報一個錯誤:
Failed to load 你的網(wǎng)址/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: *"); // 表示允許任何域名進行訪問
當(dāng)然我們還可以進行域名的限定,只允許特定的域名進行訪問
header("Access-Control-Allow-Origin:http://dedecms.sj.com");
另外我們還可以設(shè)置,允許的請求是get、post等
// 響應(yīng)類型
header("Access-Control-Allow-Methods: POST, GET, OPTIONS, PUT, DELETE");
// 響應(yīng)頭設(shè)置
header('Access-Control-Allow-Headers:x-requested-with,content-type');
補充:
何為跨域請求呢?大致可分為如下幾種情況
A.abc.com 發(fā)起一個到 abc.com/B 的ajax請求,也會有跨域的問題。之所以會有跨域問題,實則是因為www.abc.com其實同A.abc.com一樣,也是一個二級域名,而非一級域名(一級域名是http://abc.com)
對于是否允許跨域,更詳細(xì)的說明可以看下表:
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
同一域名,不同協(xié)議
不允許
http://www.a.com/a.js
http://170.32.82.74/b.js
域名和域名對應(yīng)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
不同域名
總結(jié)
以上是生活随笔為你收集整理的ajxs跨域 php_php设置header头允许ajax跨域请求的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: if js 判断成绩等级_javascr
- 下一篇: 动态规划算法php,php算法学习之动态