设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 手机 数据 公司
当前位置: 首页 > 服务器 > 安全 > 正文

奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵

发布时间:2021-01-08 20:35 所属栏目:53 来源:网络整理
导读:《奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵》要点: 本文介绍了奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵,希望对您有用。如果有疑问,可以联系我们。 作者简介: 陈思雨(RickGray) 奇虎360 高级安全研究员 奇虎 360,Web 攻防团队 0keeTeam

《奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵》要点:
本文介绍了奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵,希望对您有用。如果有疑问,可以联系我们。

作者简介:

陈思雨(RickGray)
奇虎360 高级安全研究员
奇虎 360,Web 攻防团队 0keeTeam 成员之一.专注于 Web 方面漏洞的研究,喜好研究新的漏洞类型和攻击方法.

1、前言

作者来自360信息安全部的 0KeeTeam.作者专注于 Web 漏洞挖掘和分析以及安全工具的开发.本文列举两个漏洞组合场景,讲述如何从黑客的角度去看待运维中那些容易出现的漏洞点.

2、场景一:SSRF隔山打牛攻击Readis服务

你们是否有过这样的疑问,有业务暴露在外网的时候被攻击了,安全部门的同事要求搬到内网,运维们就要通过一些简单的做法直接把业务功能搬到内网.

  • 问题一:这种做法真的就安全吗?
  • 问题二:一个绑定在本地的 Redis 服务,为什么莫名其妙地被黑客黑掉了?
  • 问题三:如何通过链接攻破企业的内网?

接下来会用两个实际漏洞组合的例子,说明这些问题出现的点到底在哪里.

2.1 SSRF漏洞原理

SSRF 如何攻击内网的 Redis 服务的?

也许大家不是很清楚 SSRF 是什么,这是服务端的请求伪造,我用一个简单的流程讲一下 SSRF 漏洞的原理和具体的表现形式.

外网的服务器 O1 提供图片代理接口,用户提供图片的链接给了 O1.O1 根据地址请求资源,将具体的内容返回给用户.

正常的逻辑是一个用户,然后请求一个图片地址,到C1的服务器里取内容.O1直接请求 C1 上的资源返回给用户,这是正常的功能逻辑.

非正常的逻辑,一个黑客或者攻击者在看到这个连接地址后会怎么做呢?

搞安全人员会这样做,将图片连接替换成不是图片的资源连接,或者内网的地址.这时候如果 O1 没有做一些资源请求方面的限制,它就会去请求它所在内网的服务器上的资源,并返回给攻击者或者黑客.

刚才写到的漏洞流程中,黑客为什么可以将内网的资源请求并返回给攻击者?

第一、 O1图片没有对传过来的连接进行类型判断.
第二、 没有判断连接指向的资源是否是图片
第三、 没有判断请求资源是否是在可允许的范围之内,可能是内网的地址,也可能是敏感的服务器地址.

如果攻击者将参数替换成内网地址,O1会毫无保留请求地址,将资源内容返回给攻击者.这是简单的 SSRF 的漏洞原理和表现形式.

2.2 SSRF漏洞利用方式

首先,我们可以利用 SSRF 进行内网的端口扫描和 Web 指纹探测.如果请求内网地址的端口是存在的,在服务器返回给攻击者信息的时候,可能有500或者错误状态码,通过这些标志可以判断扫描的端口是否开放或者关闭的状态.

其次,针对内网应用服务的攻击,通过 Struts2 可以进行请求发送.在某一些应用漏洞中,可以直接地通过 GET 请求出发.SSRF 服务器的内网有 Struts 服务,我们可以通过 SSRF 直接尝试攻击内网的 Struts2 的服务.如果真的存在漏洞,攻击者间接的使用 SSRF 进行做这些应用.

最后转换协议.在 SSRF 向服务端请求的底层实现上,一般都是利用CURL ?实现,用户所能控制的是 url 的值.如果我们讲常规的 http 协议转化成 file 协议,就会去请求本地的资源或者内网的文件,并且返回给攻击者.

gopher 协议,我们可以利用 gopher 协议对任意的端口进行应用层的数据发送.我列举了简单的例子,下面标注的是利用 gopher 协议实现请求的图.

以 gopher 协议开头,后面跟着是一个请求服务的地址,后面是一个端口.目录以下滑线作为关键字的开头,后面跟的就是具体应用层需要发送的数据.可以在 SSRF 利用中,通过 gopher 协议向任意的端口进行应用层数据的发送,这是比较关键的.

2.3 Redis未授权访问漏洞

Redis是比较流行的存储服务.大家知道的Redis漏洞中,未授权访问大家非常了解.

未授权访问这种漏洞,在我看来式因为运维人员或开发人员错误的配置造成的.一些官方的应用必须得给权限,但运维人员和开发人员在配置使用的过程中,没有按照官方的安全建议执行.

2.4 Redis未授权访问漏洞利用方式

我们可以通过攻击者未授权访问进行哪一些攻击?篡改 Redis 服务中的数据,清空数据进行破坏.

可以通过数据库备份的功能进行文件写的操作.怎样的条件下可以达到写文件的攻击?运行 Redis 服务的用户需要有一定的权限,可以往你所备份的数据库路径下写一个文件.

在 Redis 配置的时候,起用数据库备份的指令.在这儿已经列了一个 Save 和 Config.通过写文件操作,往服务器上写一个计划任务,这是后面所要执行计划任务的规则.

设置你所保存的文件名,刚刚说到了你所起的 Redis 服务,在这个路径下必须得有相应的文件操作权限,才可以成功地往里进行写入.下面是成功写入的截图.

简单说了 Redis 未授权访问利用的方式.据不完全统计,最近也经过一次扫描,发现在公网仍然存在着大约有1.5万台的服务器存在问题.

暴露在公网上的Redis有那么多,一些企业测试环境或者企业内部使用的Redis服务也是非常多.

2.5 组合利用两种漏洞攻击内网服务

我们如何攻击这些处在内网的 Redis 服务?

可以利用 SSRF 往内网发送任意的应用层数据,我们将 SSRF 漏洞和 Redis 未授权漏洞串联起来,我们就可以通过 SSRF 向内网的 Redis 服务进行攻击尝试.

有两个条件需要满足,第一存在 SSRF 漏洞的服务器必须得支持 gopher 协议,才可以成功地往内网的服务器端口进行数据发送.第二内网中确实有存在 Redis 的未授权服务.

我们将刚才 Redis 写计划任务的一系列指令,通过 gopher 协议进行封装.然后通过 SSRF 漏洞的接口,攻击者将这个参数替换成 gopher 的协议,O1解析 gopher 协议,向它处在的内网环境中的 Redis 服务进行攻击.

如果 L2 上的 Redis 服务确实存在未授权访问,且具有相应的权限,这时候攻击者就会成功地达到攻击的目标.

SSRF 堪称内网攻击的神器,在安全圈里.这是 SSRF 隔山打牛攻击内网的服务.

3、场景二:危险序列化结合脆弱中间件攻击分布式节点

3.1 危险的数据序列化

奇虎360陈思雨:通过漏洞组合利用实现企业内网入侵

利用序列化的方式攻击分布式集群.数据序列化可以在不同的两个应用程序间进行对象的传递或者方法的调用.

在这儿有一个应用A,应用A中有一个对象A1,通过序列化方式以后,将序列化的数据传递给程序B,程序B通过反序列化的操作得到B1.

在一定的本质下,A1和B1的两个对象是等价的,包括了它们两个对象的属性值和一些相应的方法.不同之处,只是它们处在不同的应用环境或者不同的底层的地址上.

在历史上出现了很多反序列化造成的问题.PHP 有一些问题被攻击者利用,在底层代码实现的时候由于不安全的反序列化操作,造成了远程命令执行问题.

在 Django 框架下有 Session 控制的问题.Java 反序列化漏洞,当时涉及到的组件很多,上到 Java 外部框架下到 Java 的扩展库都存在着远程命令执行的问题.

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读