nginx解决跨域的原理分析


本文摘自PHP中文网,作者V,侵删。

我们先来说说什么是跨域:

同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。通常不允许不同源间的读操作。

接着来说说什么是同源:

如果两个页面的协议,端口(如果有指定)和域名都相同,则两个页面具有相同的源。

nginx解决跨域的原理分析

例如:

前端server的域名为:fe.server.com

后端服务的域名为:dev.server.com

现在我在fe.server.com对dev.server.com发起请求一定会出现跨域。

现在我们只需要启动一个nginx服务器,将server_name设置为fe.server.com,然后设置相应的location以拦截前端需要跨域的请求,最后将请求代理回dev.server.com。如下面的配置:

1

2

3

4

5

6

7

server {

        listen       80;

        server_name  fe.server.com;

        location / {

                proxy_pass dev.server.com;

        }

}

这样就可以完美绕过浏览器的同源策略了。

fe.server.com访问nginx的fe.server.com属于同源访问,而nginx对服务端转发的请求不会触发浏览器的同源策略。

推荐教程:nginx教程

以上就是nginx解决跨域的原理分析的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

关于linux下如何查看nginx的并发连接数和连接状态的详细介绍

编译安装nginx却requires the pcre library

nginx php-fpm进程 怎么释放

nginx日志文件在哪

比较讲解http中499状态码和nginx下499错误

centos使用yum安装nginx提示找不到包怎么办

nginx哪个版本好

ssl证书加在nginx哪里

nginx底层什么语言

nginx怎么添加新模块?

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



打赏

取消

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

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

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

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

评论

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