三种对CORS错误配置的利用 ***

访客5年前黑客资讯882

同源战略(SOP)约束了应用程序之间的信息同享,而且仅答应在保管应用程序的域内同享。这有用避免了体系秘要信息的走漏。但与此一起,也带来了别的的问题。跟着Web应用程序和微服务运用的日益增长,出于有用意图往往需求将信息从一个子域传递到另一个子域,或许在不同域之间进行传递(例如将拜访令牌和会话标识符,传递给另一个应用程序)。
为了答应跨域通讯,开发人员有必要运用不同的技能来绕过SOP并传递灵敏信息,以至于如今也成为了一个扎手的安全问题。因而,为了在不影呼应用程序安全状况的状况下完结信息同享,在HTML5中引入了跨源资源同享(CORS)。但问题也随之而来,许多人为了便利爽性直接运用默许的装备,或是因为缺少对此的了解而导致了过错的装备。
因而,作为安全分析师/工程师,了解怎么运用过错装备的CORS标头非常重要。这也将有助于你在灾祸发作之前更好地对其进行弥补。
什么是 CORS?
CORS是一个W3C规范,全称是”跨域资源同享”(Cross-origin resource sharing)。它答应浏览器向跨源(协议 + 域名 + 端口)服务器,宣布XMLHttpRequest恳求,然后克服了AJAX只能同源运用的约束。
CORS需求浏览器和服务器一起支撑。它的通讯进程,都是浏览器主动完结,不需求用户参加。关于开发者来说,CORS通讯与同源的AJAX通讯没有不同,代码彻底相同。浏览器一旦发现AJAX恳求跨源,就会主动增加一些附加的头信息,有时还会多出一次附加的恳求,但用户不会有感觉。
因而,完结CORS通讯的要害是服务器。只需服务器完结了CORS接口,就能够跨源通讯。
要害 CORS 标头
有许多与CORS相关的HTTP标头,但以下三个呼应标头关于安全性最为重要:
Access-Control-Allow-Origin:指定哪些域能够拜访域资源。例如,假如requester.com想要拜访provider.com的资源,那么开发人员能够运用此标头安全地颁发requester.com对provider.com资源的拜访权限。
Access-Control-Allow-Credentials:指定浏览器是否将运用恳求发送cookie。仅当allow-credentials标头设置为true时,才会发送Cookie。
Access-Control-Allow-Methods:指定能够运用哪些HTTP恳求办法(GET,PUT,DELETE等)来拜访资源。此标头答应开发人员经过在requester.com恳求拜访provider.com的资源时,指定哪些办法有用来进一步增强安全性。
三个进犯场景
运用CORS标头中过错装备的通配符(*)
最常见的CORS装备过错之一是过错地运用比如(*)之类的通配符,答应域恳求资源。这一般设置为默许值,这意味着任何域都能够拜访此站点上的资源。例如:
GET /api/userinfo.php
Host: www.victim.com
Origin: www.victim.com
当你发送上述恳求时,你将取得具有Access-Control-Allow-Origin标头设置的呼应。请参阅以下呼应代码。
HTTP/1.0 200 OK
Access-Control-Allow-Origin: *
Access-Control-Allow-Credentials: true
在此示例中,标头装备了通配符(*)。 这意味着任何域都能够拜访资源。
在测验咱们客户的Web应用程序时,咱们留意到了这种过错装备。咱们能够运用它来获取用户信息,如名字,用户ID,电子邮件ID,并能够将此信息发送到外部服务器。鄙人图中,咱们将REQUEST Origin从受害者域修改为进犯者域。

以下是咱们收到的呼应,这意味着受害域答应拜访来自一切站点的资源。咱们的进犯事例中的Testing.aa *** 网站。

因为该站点同享来自任何站点的信息,因而让咱们进一步的运用咱们自己的域来运用它。咱们创建了名为https://testing.aa *** 的域,并将其嵌入缝隙运用代码,以便从易受进犯的应用程序中盗取秘要信息。当受害者在浏览器中翻开https://testing.aa *** 时,它会检索灵敏信息并发送给进犯者的服务器。以下是咱们能够收集到的信息,如下图所示。

将信赖域通配符作为 Origin
另一种常见的过错装备是答应与部分验证的域名同享信息。例如,以下恳求:
GET /api/userinfo.php
Host: provider.com
Origin: requester.com
呼应如下:
HTTP/1.0 200 OK
Access-Control-Allow-Origin: requester.com
Access-Control-Allow-Credentials: true
考虑一下开发人员是否装备了CORS来验证“Origin header”URL,白名单域仅仅“requester.com”。现在,当进犯者建议如下恳求时:
GET /api/userinfo.php
Host: example.com
Connection: close
Origin: attackerrequester.com
服务器会呼应:
HTTP/1.0 200 OK
Access-Control-Allow-Origin: attackerrequester.com
Access-Control-Allow-Credentials: true
发作这种状况的原因可能是后端装备过错,例如:
if ($_SERVER['HTTP_HOST'] == '*requester.com')
 {
  //Access data
  else{ // unauthorized access}
}
咱们在客户的一个应用程序中遇到了这个问题。主机域“provider.com”信赖以主机名“requester.com”结束的一切来历,例如“attackerrequester.com”。 因而,咱们将origin头部篡改为attackerrequester.com并持续履行恳求。

在以下呼应中,相同的origin在呼应Access-control-Allow-Origin标头中,这意味着provider.com域答应同享资源到以requester.com结束的域。

[1] [2]  黑客接单网

相关文章

百度浏览器的隐私安全问题剖析

首要发现 百度阅读器是微柔和安卓渠道上的一种网络阅读器,个人用户在向服务器传输数据时进行加密,就算加密了也很简略被解密。阅读器更新时或许很轻易地被中心攻击者运用,履行恣意代码。 安卓版别的百度阅读器...

探究Flask/Jinja2中的服务端模版注入(二)

在探究Flask/Jinja2中的服务端模版注入Part1中,我开端的方针是找到文件的途径或许说是进行文件体系拜访。之前还无法达到这些方针,可是感谢朋友们在之前文章中的反应,现在我现已可以完成这些方针...

子域名收集思路与技巧整理

前语 本文合适Web安全爱好者,其中会说到8种思路,7个东西和还有1个小程序,看本文前需求了解相关的Web基础知识、子域名相关概念和Python 程序的基础知识。 感谢我的老友龙哥的技巧大放送以及Or...

探究Flask/Jinja2中的服务端模版注入(一)

假如你还没听说过SSTI(服务端模版注入),或许对其还不够了解,在此之前主张咱们去阅览一下James Kettle写的一篇文章。 作为一名专业的安全从事人员,咱们的作业便是协助企业安排进行危险决议计划...

JSP运用过滤器避免SQL注入

 什么是SQL注入进犯?引证百度百科的解说: sql注入_百度百科: 所谓SQL注入,便是通过把SQL指令刺进到Web表单提交或输入域名或页面恳求的查询字符串,终究抵达诈骗服务器履行歹意的SQL指令。...

xHunt:针对科威特航运组织的攻击行动-黑客接单平台

2019年5月至6月,unit42安全团队在一起针对科威特航运业的进犯事情中,检测到了一个新后门东西——Hisoka,它的作用是下载几个的定制东西进行后缝隙运用,一切东西好像都由同一个开发人员创立,最...