nginx 跨域_Nginx配置跨域-只有暴漏了问题,才能解决问题

背景

前端仔试过了:node跨域、vue Proxy跨域、jq跨域、后台大佬协助跨域,

这次跨域就是要用 nginx !!!其他我不管!

3ad7e582cce3842a01172370410267a4.png

html代码

let res = fetch('http://localhost:8088/follow').then(res=>{console.log(res)})

node,server代码

const http = require('http')const server = http.createServer((req,res)=>{  console.log(req)  res.writeHead(200,{'Content-Type':'text-plain'});  res.end('Hello Node');})server.listen(3333, () => {  console.log(`server running at 3333`)})

nginx配置

location  /follow/ {proxy_pass http://localhost:3333;}或者location  /follow/ {proxy_pass http://127.0.0.1:3333;}

报错

729fd065a0acb112560b07b2f15ac6f1.png

Access to XMLHttpRequest at http://localhost:8088/follow' from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

现象

不管怎么调,

  1. 修改fetch的url
  2. 修改nginx正则匹配规则
  3. 给location添加配置头

都无法正确完成nginx跨域。人生很灰暗,感觉自己像是进入了死胡同。

到底是什么原因呢?难道我们一遍遍的试就没有一次是对的吗?

原因

少加了一条代码:add_header 'Access-Control-Allow-Origin' '*';

server {      listen       8088;      server_namelocalhost;      location /follow/ {         add_header 'Access-Control-Allow-Origin' '*';         proxy_pass http://127.0.0.1:3333/;      }}

加完后就能解决!!!

271bf63238b770ffb2c1431cf5b6512f.png

如果还没解决呢?继续看

使用nginx要点:

  1. nginx监听端口,一定要未被占用。
  2. nginx监听端口可以随意设置,但请求url的主机名、端口号要一致,一变都变。
  3. 此时,可以跟 远程(后台)接口地址不一

分析:

能解决的代码知识都在这了,如果还没走通:

  1. 重启nginx,看看运行有没有问题。
  2. 比对接口、主机名是否一致。

nginx小贴士:

// 启动start nginx// 或者直接点击nginx.exe// 重启nginx -s reload// 立即停止nginx -s st

Q:方法你都懂,为什么还是会报错?

A:懂方法可以确保大方向没问题,报错基本上是不熟悉,理解不到位造成的 漏、忘。

结语:

说实话,'Access-Control-Allow-Origin' '*',这句代码我知道,node服务会需要,但是。。。唉。

加它是从后台层面解决跨域的方法,我只记住了 后台 却完全忘记了 服务器 天真的以为nginx很强大解决跨域也需要它吗?太尴尬了,太浅显了,太年轻了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值