php跨域的一些问题

产生跨域的原理简单来说就是 A域名前端-》请求-》B域名后端

 

以下分几个场景分别述说PHP各个场景的解决方案(其实每个语言都差不多):

 

一切缘由于响应头,不用多想,只要响应头对了就不会存在跨域的问题,最简单的就是:

 

 在PHP代码里面加上,不管在哪里,前或者后面结束的时候再加都能够成功的

header('Access-Control-Allow-Origin:*'); // *代表允许任何网址请求


可以在nginx或apache的配置上做处理,这里只列举nginx

server
{
listen 9902;
server_name 127.0.0.1;
index index.php index.html index.htm default.php default.htm default.html;
root /www/wwwroot/www.trade.com/public;

#代表允许任何网址请求(只加这个即可,无太多需求后面那些可以不要)
add_header Access-Control-Allow-Origin *;

#代表允许任何方法请求
add_header Access-Control-Allow-Methods *;

#代表允许任何头部请求
add_header Access-Control-Allow-Headers *;

.......
}

 

 

注:跨域不能设置重复,不然也会出现跨域的错误,比如nginx上设置了,php上也设置就会出现

 

 



Access to XMLHttpRequest at 'https://********.com/projects/api/index.php/cmsWenJuan/wenjuan'
from origin 'http://39.107.70.68:9902' has been blocked by CORS policy: The 'Access-Control-Allow-Origin' header contains multiple values '*, 0', but only one is allowed.

就是已被CORS策略阻止:“Access Control Allow Origin”标头包含多个值“*,0”,但只允许一个值。


 
posted @ 2021-05-21 16:24  郑筱筱  阅读(186)  评论(0编辑  收藏  举报