nginx怎么解决跨域问题


本文摘自PHP中文网,作者藏色散人,侵删。

如何用Nginx解决前端跨域问题?

前言

在开发静态页面时,类似Vue的应用,我们常会调用一些接口,这些接口极可能是跨域,然后浏览器就会报cross-origin问题不给调。

最简单的解决方法,就是把浏览器设为忽略安全问题,设置--disable-web-security。不过这种方式开发PC页面到还好,如果是移动端页面就不行了。

解决办法

使用Nginx转发请求。把跨域的接口写成调本域的接口,然后将这些接口转发到真正的请求地址。

举个栗子

例如我们在开发一个Vue应用。

原先:

调试页面是:http://192.168.1.100:8080/

请求的接口是:http://ni.hao.sao/api/get/info

步骤一:

请求的接口是:http://192.168.1.100:8080/api/get/info

PS:这样就解决了跨域问题。

步骤二:

安装好Nginx后,去到/usr/local/etc/nginx/目录(这是Mac的),修改nginx.conf文件。

步骤三:

把默认的server配置注释掉。

在下面增加:

1

2

3

4

5

6

7

8

9

10

11

12

server{

     listen 8888;

     server_name  192.168.1.100;

 

     location /{

         proxy_pass http://192.168.1.100:8080;

     }

 

     location /api{

         proxy_pass http://ni.hao.sao/api;

     }

 }

保存后,启动Nginx。

PS:并不需要太了解Nginx的配置,很简单的。

步骤四:

访问:http://192.168.1.100:8888/

搞定。

PS:注意访问的端口是‘8888’,有其他域的地址继续加location就行了。

错误示范

我一开始不太懂Nginx的配置,以为可以如下配置。

阅读剩余部分

相关阅读 >>

网页出现nginx什么意思

nginx源码是什么语言

nginx在centos7.3下的部署

nginx反向代理后,如何防止ddos攻击

nginx error什么意思

nginx和tomcat怎么在一起工作

nginx英文怎么读

linux如何查看nginx是否启动

修改nginx上传文件大小配置

怎么更改nginx配置文件路径

更多相关阅读请进入《nginx》频道 >>



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...