简单请求的跨域以及安全校验

前言

提起跨域,可能大多数猿们都不陌生,在工作中多多少少都有碰到,现在比较主流的跨域模式有cors和jsonp:

  • jsonp:利用浏览器对script资源的引用没有同源规则的限制,通过动态插入script标签的方式(其实就是跨域限制的一个漏洞),将地址指向第三方的地址,比如<script src="http://www.test.com/test?a=1&b=2"></script>,同时提供一个回调函数来处理第三方响应的json数据callback({"a": 1, "b": 2})。当然,客户端可以随意定制回调函数来处理返回数据,主需要跟服务端提前约定好即可。

    注:需要注意的是:jsonp的跨域模式其实就是一种脚本注入的行为,它可能会造成一些不安全的行为。而且,它只支持get请求,不支持post等其它类型的http请求,而且不能解决不同域的两个页面之间互相进行JavaScript调用的问题。

  • cors:Corss-Origin Resource Sharing,跨域资源共享,它是一个W3C标准,允许浏览器向跨源服务器发起XMLHttpRequest请求。

本文将讲解简单请求的cors跨域服务端如何做?安全校验如何做?

简单请求的cors跨域

注:什么叫简单请求?
浏览器将cors请求分为两类:简单请求(simple request)和非简单请求(not-so-simple request),只要同时满足以下条件的就属于简单请求,否则都属于非简单需求:

  1. 请求方法是HEADGETPOST之一;
  2. HTTP的头信息不超出以下几种字段:
    • Accept
    • Accept-Language
    • Content-Language
    • Content-Type:只能取三个值application/x-www-form-urlencodedmultipart/form-datatext/plain
    • Last-Event-ID

当然浏览器对于这两种请求的处理也是有区别的,非简单请求浏览器会增加一次http查询请求(预检请求),先询问服务器当前请求域名是否在服务器的许可名单之中以及可以使用哪些http动词和头信息字段,只有得到正确的答复,浏览器才会发起一次正式的XMLHttpRequest请求,否则报错。

对于简单请求的cors跨域,具体的流程如下:

  1. 浏览器发起请求,在请求header中增加Origin字段,表示本次请求来自哪个源,具体的请求header如下所示:

    Accept:*/*
    Accept-Language:zh-CN,zh;q=0.9
    Connection:keep-alive
    Origin:https://miao.test.com
    User-Agent:Mozilla/5.0...
    
  2. 服务端接收到请求后,判断Origin指定的源,如果在允许调用的范围呢,服务端正常返回,需要注意的是,服务端在返回时需要在header中设置Access-Control-Allow-Origin字段,浏览器会判断该字段是否包含请求中的Origin值,如果包含,响应正确,否则,浏览器会抛出错误,正确响应header如下所示:

    Access-Control-Allow-Credentials:true
    Access-Control-Allow-Origin:https://miao.test.com
    Access-Control-Expose-Headers: FooBar
    Content-Type: text/html; charset=utf-8
    

    上文响应header中有3个与cors请求相关的字段:

    • Access-Control-Allow-Origin:必须要有的字段,它的值可以是请求header的Origin的值,也可以是*(表示接受任何域的请求),需要注意的是,如果为*的话,会有一系列的安全问题,建议不要这么做;
    • Access-Control-Allow-Credentials:可选字段,表示是否允许发送cookie,true表示允许,另外该字段的值只能设置为true,如果服务端不需要浏览器发送cookie,删除该字段就可以。需要注意的是,如果需要发送cookie还需要前端配合的,前端必须要在ajax请求中打开withCredentials属性;
    • Access-Control-Expose-Headers:可选字段,可以通过该字段指定获取响应header中的某个字段的值。

知道流程之后,那么对于cors跨域的安全怎么做也就一目了然了,可以直接判断请求的Origin是否在允许跨域的域名白名单内,如果在,则服务端允许返回正确响应,否则,服务端拦截,响应异常。接下来给个简单的例子吧,一看就会用:

安全校验Interceptor

跨域请求安全校验

服务端Controller处理
服务端的处理方式与正常同源请求响应一样,不需要像jsonp那样需要包装响应数据:

@RequestMapping(value = "/test.json", method = RequestMethod.POST)
  public void test(HttpServletRequest request, ModelMap modelMap) {
      try {
          modelMap.put("success", true);
          modelMap.put("data", "test");
      } catch (Exception e) {
          modelMap.put("success", false);
          modelMap.put("errCode", 1001);
          modelMap.put("errMsg", "系统异常");
      }
  }

到这里,简单请求的cors模式跨域就大致介绍完了,非简单请求大家在工作中其实不太常遇到,在这里我就不做详细的介绍了,以后遇到了再做相关介绍。就让我小小的放飞下自己~~~~~~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 前言:对于跨域请求,很早之前就有去了解过,但因为一直关注的都是服务器后端开发,故也就仅仅停留在概念的理解上而没有机...
    ken_ljq阅读 89,756评论 6 128
  • 题目1.什么是同源策略? 同源策略(Same origin Policy): 浏览器出于安全方面的考虑,只允许与本...
    FLYSASA阅读 1,719评论 0 6
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 1. 什么是跨域 跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScri...
    cbw100阅读 6,328评论 2 86
  • 什么是同源策略 同源策略(Same origin Policy):浏览器出于安全方面的考虑,只允许与本域下的接口交...
    _Dot912阅读 851评论 0 3