知识屋:更实用的电脑技术知识网站
所在位置:首页 > 网络安全 > 技术文献

更小巧更强悍—Eval版ASP木马原理解析

发布时间:2011-06-29 18:59:32作者:知识屋

随着网络安全的普及,管理员防范WebShell的技术也有所提高,以前那种直接放上一个WebShell的时代正慢慢离我们而去,故现在的WebShell越来越注重其隐蔽性。WebShell的隐藏技术也发展得很快,从改变代码大小写到C/S模式,都是牛人们智慧的结晶。说到C/S模式,是不是让你想起ASP下那个“Execute Request("#")”一句话后门,呵呵,今天我也跟大家介绍一个ASP一句话后门,不过不是execute,而是另一个函数——eval。   
嗯,先来说说eval后门的原理和使用方法,不会的听仔细啦。偶们知道在asp里面有个execute函数专门用来执行asp代码,这个就类似于Javascript里面的eval函数。所以execute就可以拿来做成一句话后门:execute request("x")。不过,当POST的参数x为空时execute函数会出错,所以你得加一句容错语句才是。其实VBScript里面也有eval函数的,不知道能不能拿来用,嗯,看看它功能先:   

Eval函数   
计算一个表达式的值并返回结果。   

[result = ] Eval(expression)   
参数    
result   
可选项。 是一个变量,用于接受返回的结果。如果未指定结果,应考虑使用 Execute 语句代替。   

expression   
必选项。可以是包含任何有效VBScript表达式的字符串。   

小提示:   
在VBScript 中,x = y可以有两种解释。第一种方式是赋值语句,将y的值赋予x。第二种解释是测试x 和y是否相等。如果相等,result为True;否则result为False。Eval方法总是采用第二种解释,而Execute语句总是采用第一种。   
注意,参数expression“可以是包含任何有效VBScript表达式的字符串”。呵呵,那不就是暗示我们eval能执行任意代码嘛。不过看那个说明,eval总是把赋值语句解释成判断句,岂不是不能拿来赋值。呵呵,不要紧,如果我们拿eval来执行execute再由execute执行任意代码呢?呵呵,eval后门诞生了!   
同execute相比,eval有个好处就是当参数为空不会出错,所以迄今为止最短的ASP后门就是“”。数数吧,是不是比以前的都短啊,呵呵。   
把eval函数插入到一正常的ASP文件,你的后门就留好了(如果能够把文件最后修改时间改回去就更好了)。现在可以执行任意代码了,当然,代码需要你用客户端POST上去。   
客户端用网页实现很是方便。海阳顶端有个eval客户端,好像是用session保存代码然后执行,不过我试了几次都不行,唉,还是自己写一个吧。   
我做的这个客户端与海阳的不同,是由各个功能分别构成,每个功能使用一个htm页面,对应一段代码,放在网页的隐藏域。参考了冰狐浪子那个微型ASP后门客户端的网页结构,感谢之。   
先前不是说了,我们得用eval执行execute再由execute执行代码。所以隐藏域的内容类似于“execute("response.write(""Hello , World !""):response.write(""   
"")”——注意在引号之中的引号得双写;而且execute中的字符可以使用回车换行也可以用冒号代替回车换行。   
这样子还不够,我们还要“斩头去尾”。斩头呢就是把我们的后门代码执行之前的数据清空,去尾呢就是把后门执行代码之后的数据清空,不能让其他无用数据影响我们看回显嘛。这个分别用response.clear和response.end来完成。Ok,经过一番斩头去尾,我们的隐藏域就成了:“resposne.clear:execute("response.write(""Hello, World!""):response.write(""   
""):response.end")”。   
这里顺便说一下,去年不是有牛人提出用#include一图片的形式来隐藏后门,图片最后是一段asp代码。当时不是说这个方法执行代码之后会显示图片而没有回显吗,其实是有回显的,你把图片保存后用十六进制编辑软件打开,原来回显内容在图片末尾。呵呵,想到了吧,用response.clear就可以清除图片显示出回显啦。   
现在的任务就是找点ASP后门的代码改动改动再结合Javascript做成html文件就是了,有兴趣的朋友看代码,在此就不赘述咯。另外,execute函数也可以使用这个客户端的哦。   
这种后门的优点就是体积小,隐蔽性高,杀毒软件不能查杀,而且所有提交的数据都是POST方式,IIS日志不会记录;缺点是每次执行代码都会有大量数据传送,而且代码通过execute执行速度会慢些。   
这种执行代码还有一个好处就是可以把POST的代码加密,绕过IDS,呵呵,这个嘛以后再说咯 

(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜