apache配置 - 跨域资源共享(Cross-Origin Resource Sharing)

背景:服务器提供https的api给浏览器ajax调用,并要允许跨域访问:

 

1. httpd.conf

去掉注释LoadModule headers_module modules/mod_headers.so

2. 修改以下配置

 

 

 

 

这里一定要加Header add Access-Control-Allow-Headers "Content-Type"。

 

猜测是因为客户端要发送的类型是application/json,

所以在发送的OPTIONS请求头里出现:

 

Access-Control-Request-Headers:Content-Type, Accept

 

3. 重启apache

 

 

参见:http://www.w3.org/TR/cors/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nginx 是一款常用的开反向代理服务器软件,也可以用来做负载均衡和缓存服务器。当我们在开发前端项目时,由于同策略的限制,可能会遇到跨域请求的问题。为了解决跨域问题,我们可以通过配置 nginx 来实现。 在使用 nginx 配置跨域时,常用的配置项是 "Access-Control-Allow-Origin"。当我们将这个配置项设置为 "strict-origin-when-cross-origin" 时,表示允许同域请求和一部分跨域请求。 "strict-origin-when-cross-origin" 是一个比较灵活的选项,它会根据请求的类型自动判断是否允许跨域访问。对于同域请求,它会自动将 Origin 标头加入到 Access-Control-Allow-Origin 响应标头中,从而实现同请求。 然而,有时候我们可能会遇到配置不生效的情况。可能的原因有: 1. 配置项没有正确设置。我们需要确保配置项 "Access-Control-Allow-Origin" 的值为 "strict-origin-when-cross-origin",并且正确地将该设置添加到 nginx 的配置文件中。 2. 缓存问题。如果之前的响应已经被缓存在客户端或代理服务器中,那么新的配置可能无法立即生效。可以尝试清除缓存并重新测试。 3. 其他配置项冲突。nginx 的配置文件可能包含其他与跨域相关的配置项,这些配置项可能会导致冲突。需要检查配置文件中是否存在与跨域请求相关的其他设置,如 "Access-Control-Allow-Methods" 或 "Access-Control-Allow-Headers"。 4. 重启nginx服务。在修改了nginx配置文件后,需要重启nginx服务才能使配置生效。 总之,在配置 nginx 跨域时,我们需要确保正确设置 "Access-Control-Allow-Origin" 为 "strict-origin-when-cross-origin",处理好可能存在的缓存问题,避免其他配置项冲突,并在修改配置文件后重启 nginx 服务,以确保配置生效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值