本文主要介绍web.config文件在渗透中的作用,即可上传一个web.config时的思路,话不多说,开始正题。首先我们来看一下web.config是什么,援引百度百科的介绍:
Web.config文件是一个XML文本文件,它用来储存ASP.NETWeb 应用程序的配置信息,它可以出现在应用程序的每一个目录中。在运行时对Web.config文件的修改不需要重启服务就可以生效.
关键词:xml文本、.net配置、无需重启,这几个特性就决定了其在渗透中的作用,我们来看下具体操作。
以下实验环境为:
windows server 2008
iis 7
.net 3.5
首先通过实验了解什么是重定向:数据流重定向数据流重定向就是将某个指令执行后应该要出现在屏幕上的数据,将它们传输到其他的地方。)
在iis中有一项为url redirect也就是用来进行url重定向的,当我们可以长传一个web.config的时候我们就可以使用这种方式来进行钓鱼攻击,在这里要注意的是,不同的iis版本的配置稍有不同,以本次环境中的iis7为例,假如我们想让目标网站跳转到baidu,我们只需要这样写我们的web.config:
中间的一行为我们具体实现的代码,即开启重定向并重定向到百度,剩下的都是服务默认的自带的,相当于模板,此时我们访问目标站点,就会跳转到baidu了。
而大于等于iis7版本就稍微复杂一些,因为在这之后多了一个url write功能,其中包含了url重定向,所以很多开发选择使用这个功能进行操作。我们来看一下,如果为url write该如何去做。假如我们在url write定义了一个规则为:为所有不带斜杠(/)的网址,自动加上斜杠(/),比如下图这样:
那么我们的web.config就会自动生成以下内容:
看起来有些难懂,下面稍微给大家说一下,首先在url write分为入站规则()和出站规则()他们需要写在的元素内,我们一般钓鱼只考虑入站规则,AddTrailingSlashRule1为一个新的规则名字,可随意定义,若stopProcessing指定为true则若当前请求与规则匹配,则不再匹配其他请求。为进行匹配的url,一般使用正则表达式的形式,而元素告诉IIS如何处理与模式匹配的请求,使用type属性来进行处理,一般有以下几个:
None:
Rewrite:将请求重写为另一个URL。
Redirect:将请求重定向到另一个URL。
CustomResponse:向客户返回自定义响应。
AbortRequest:删除请求的HTTP连接。
而redirectType属性指定要使用永久重定向还是临时重定向。剩下的大家可以查阅msdn上面的手册,写的非常详细。说了这么多,估计大家就能明白怎么去写web.config了,给出大家一个url write的web.config钓鱼模板,可自行进行修改:
因为web.config不需要重启服务,所以当我们能够传一个web.config上去的时候,我们也就达到了我们的目的,也有可能运维人员已经写好了一些规则,我们不想贸然惊动管理者的话,如果此时我们可以上传.shtm或.shtml文件,并使用以下代码来读取web.config的内容。
并根据读取的内容来进行后续操作。
(二)使用web.config进行xss
这是一种比较古老的技术,依靠web.config的name属性,来构造一个xss,前提是iis6或者更低的版本不支持这类攻击,假设我们上传的web.config内容如下:
XSS
则我们访问该文件时则会弹出xss
(三)使用web.config运行asp代码
这类攻击 *** 其实也不是什么很稀奇的技术,因为web.config可以操控iis服务器,那么我们可以去调用system32inetsrvasp.dll文件,来达到运行任意asp代码的目的。比如下面这样:
”)
'如果您通过打开web.config文件看到3,它正在运行ASP代码!
Response.write(1 + 2)
Response.write(“
此时访问文件,则会输出3,运行其他的代码同理哦。
(四)使用web.config绕过hidden segments
在iis7以后,微软为了增加其安全性增加了hidden segments功能对应请求过滤模块,也就是对一些不想让其他人访问的东西进行过滤,在被访问时返回给客户端一个404.8的状态码。一般在web.config中使用来进行指定隐藏的值。比如我们设置了一个文件夹为hiddenSegments,那么在访问时就是下图这种情况。
比如文件夹为_private则对应生成的web.config内容如下
而此时我们可以通过上传web.config的形式,来绕过这种过滤。
因为过滤的本质是使用的APP_Data或者App_GlobalResources进行的添加,我们将其删除掉即可。
(五)使用web.config进行rce
这个跟执行asp代码原理上差不多,主要是使用AspNetCoreModule模块去调用cmd进行命令执行。
这个过程通过去访问服务器上的backdoor.me进行触发,因为是在服务端进行执行的,这时候我们可以如调用powershell,来返回一个反向的shell。
(六)使用系统秘钥来反序列化进行rce
这个是一种.net的反序列化操作,有兴趣的朋友可以参考orange师傅在hicton上出的题
(七)使用web.config启用 XAMLX来getshell
XAMLX文件一般用于工作流服务,使用消息活动来发送和接收Windows Communication Foundation(WCF)消息的工作流。而我们可以使用该文件进行命令执行,一般有两种 *** ,一种是反序列化,另一种就是其本身的文件浏览功能在浏览上传的文件时,执行命令。以第二种为例,代码内容如下:
[System.Diagnostics.Process.Start(“ cmd.exe”,“ / c calc”)。toString()]
发送一个帖子请求即可调用该文件进行命令执行:
POST /uploaded.xamlx HTTP / 1.1
主机:192.168.0.105
SOAPAction:testme
内容类型:text / xml
内容长度:94
所以我们也可以使用这种 *** 来进行反弹shell。
但是该文件并非全部开启,若目标服务器启用了WCF服务我们可以使用下面的web.config进行启用这类文件
(八)使用web.config绕过执行限制
在一个可读写的目录里无法执行脚本, 可以通过上传特殊的 web.config 文件突破限制.比如这种:
发布后即可访问,运行代码。
总结
除了这些还有像存储型xss、json攻击等因为各类限制较多,本人没有在文中指出,有兴趣的可以自行了解。
如何查看别人的微信聊天记录_您身边的调查专家查别人微信上的聊天 以前,我们一直想寻找安全靠谱的邮箱服务,Gmail 是首选,原因主要有几个:Google 这个大品牌的背书安全确实做得很好,关于这点我...
不同月龄的宝宝尿不湿的使用量是不一样的,要根据宝宝的便便情况具体判断,而换尿不湿其实是件简单但是又有着一定的技巧的工作,那么,宝宝每天要用多少尿不湿?接下来友谊长存小编就来说说。 宝宝每天要用多少尿...
本文目录一览: 1、2001年5月那场轰动全球的中美黑客大战是什么回事? 2、2001中美黑客战争的缘由,过程,结果是怎样的? 3、历史上最著名的几次黑客事件 4、中美黑客大战是否真有其事...
⒈收到一份黑客勒索邮件,该怎么办?收到一份黑客勒索邮件拨打12377开展检举。除开能够根据“12377”开展私人信息维护保养外,还能够对“互联网勒索和有偿服务删。 ⒉QQ邮箱收到一封怪异的邮件。求高...
本文目录一览: 1、“一夜走红”的中国黑客,把中国国旗插在白宫网站上,后来怎样了? 2、红衣黑客是真的吗 3、中国顶级黑客,为报南海王伟撞机之仇,将国旗插到了白宫上,他是谁? 4、中国的黑...
Lol是一款以腾讯官方为意味着的出色的英雄对英雄竞技类游戏,在中国有着上亿游戏玩家。假如你一直在玩lol的情况下碰到lol看不见赛事的难题,那时很痛楚的。为了更好地让大伙儿更强的打游戏,下边的小系...