美文网首页nginx 教程
nginx 跨域访问(12)

nginx 跨域访问(12)

作者: 瓦力博客 | 来源:发表于2019-01-21 12:04 被阅读45次

获取全套nginx教程,请访问瓦力博客

小菜一直在从事前端,之前面试时被人问到,也是一脸懵逼。这篇博客小菜就来谈谈自己对跨域的理解。要搞清楚跨域,我们首先要搞清楚几个问题。1.什么是跨域?2.造成跨域
的原因?3.为什么要禁止跨域?4.我们为什么要解决跨域?5.如何解决跨域?相信这几个问题问下来,小伙伴会对跨域有所了解。

1.什么是跨域

跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript实施的安全限制。
同源策略限制了一下行为:

● Cookie、LocalStorage 和 IndexDB 无法读取

● DOM 和 JS 对象无法获取

● Ajax请求发送不出去

2.造成跨域的原因

XmlHttpRequest同源策略:禁止使用XHR对象向不同源的服务器地址发起HTTP请求

跨域场景

URL 说明 是否允许通信
http://www.a.com/a.js
http://www.a.com/b.js
同一域名 允许
http://www.a.com/lab/a.js
http://www.a.com/script/b.js
同一域名下不同文件夹 允许
http://www.a.com:8000/a.js
http://www.a.com/b.js
同一域名,不同端口 不允许
http://www.a.com/a.js
https://www.a.com/b.js
同一域名,不用协议 不允许
http://www.a.com/a.js
http://70.32.92.74/b.js
域名和域名对应ip 不允许
http://www.a.com/a.js
http://script.a.com/b.js
主域相同,子域名不同 不允许
http://www.a.com/a.js
http://a.com/b.js
同一域名,不用二级域名 不允许
http://www.cnblogs.com/a.js
http://www.a.com/b.js
不同域名 不允许

3.为什么要禁止跨域

浏览器禁止跨域主要是是安全问题。主要是为防止CSRF攻击。

CSRF是什么

CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session riding,缩写为:CSRF/XSRF。

CSRF可以做什么

你这可以这么理解CSRF攻击:攻击者盗用了你的身份,以你的名义发送恶意请求。CSRF能够做的事情包括:以你名义发送邮件,发消息,盗取你的账号,甚至于购买商品,虚拟货币转账......造成的问题包括:个人隐私泄露以及财产安全

ssl

4.如何解决跨域

解决跨域问题网上有很多种,如jsonp,nginx,后台服务器修改Response Headers头信息等等都可以。这篇博客是在nginx系列,所以小菜只介绍nginx中如何配置跨域

1.add_header

add_header配置项是属于ngx_http_headers_module模块传送门{:target="_blank"}

Syntax: add_header name value [always];
Default: —
Context: http, server, location, if in location

示例配置

server {
    listen       80; 
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    # *是指允许所有域名访问,一般只需要配置自己信任的域名Access-Control-Allow-Origin: www.example.com
    add_header Access-Control-Allow-Origin *; 
    add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,OPTIONS;
    
    ...
    
}
ssl

从上面的截图来看,nginx配置和服务器后台处理跨域问题的方式一致,其主要操作是给Response Headers头信息添加

Access-Control-Allow-Origin: *  
Access-Control-Allow-Methods: GET,POST,PUT,DELETE,OPTIONS

来解决跨域的问题,如果要在深入一点的话。小菜在这里贴上一篇博客。跨域资源共享 CORS 详解。想更深入了解的同学就去看看阮一峰这篇博客

相关文章

  • nginx 跨域访问(12)

    获取全套nginx教程,请访问瓦力博客 小菜一直在从事前端,之前面试时被人问到,也是一脸懵逼。这篇博客小菜就来谈谈...

  • Nginx 允许多个域名跨域访问

    参考: Nginx 允许多个域名跨域访问 当浏览器发起ajax请求到其他域名时,会出现跨域的问题,在nginx上的...

  • nginx跨域访问

    前端跨域问题解决方式: 1.与服务端部署到同域上(正常部署) 2.CORS 同域安全策略CORS(Cross-Or...

  • 浏览器跨域的那些事

    整理中 目标: 了解跨域 解决跨域 服务器配置跨域(java, nginx) 前端调试时配置解决跨域 一、什么是跨...

  • nginx反向代理

    前端调用接口的时候跨域了怎么办呢,如下代码跨域: 通过nginx反向代理下载nginx:http://nginx....

  • 关于设置env等环境变量的思考

    1、如何处理跨域后台处理跨域前端处理跨域浏览器处理跨域 前端本地处理跨域:代理线上跨域的处理方式:Nginx反向代...

  • Nginx跨域

    Nginx解决跨域问题(CORS) CORS(Cross-Origin Resource Sharing) 跨域资...

  • ajax跨域--nginx反向代理

    用nginx反向代理实现跨域,是最简单的跨域方式。只需要修改nginx的配置即可解决跨域问题,支持所有浏览器,支持...

  • NGINX配置允许跨域访问

    在服务器的NGINX配置文件中添加一下代码 add_header 'Access-Control-Allow-Me...

  • Nginx配置网站跨域访问

    最近在一个项目中遇到网站跨域访问的问题,花了半天时间来研究,并记录一下: 问题: 两个网站,A网站需要调用B网站的...

网友评论

    本文标题:nginx 跨域访问(12)

    本文链接:https://www.haomeiwen.com/subject/nmfcjqtx.html