这只是个小测试,验证一下自己的想法。
0 l! @) m' y0 a* ^% O0 z很早的时候,就遇到过服务器不允许POST的情况+ u- D) n4 n1 c
当时因为忙,就没有深入的去想,昨天又遇到一次,是个后台带SQL语句执行的,导出个一句话之后发现菜刀连不上,不允许POST。
- X0 Y2 `! M6 c这个时候,不可能直接SQL执行导出个大马的,那该怎么办呢?; @5 J: P: A! Y9 p$ n) ?
于是我就寻思着用GET的方式向刚才导出的一句话提交数据。- J; E) K# S. O9 s& f: c8 G
今晚不是很忙,就写出来测试结果。
& I: y& W% K4 v( ]1 q" |8 M在ASP环境下,一句话木马一般用2个函数执行:eval和execute。
3 u1 N, K O |, P先来写个eval的一句话,然后用GET向他提交数据- s6 a Z/ b8 s' ?" m" B1 B
$ K2 g& O6 ]! k! Q0 c' Y7 z5 d" y6 b+ _! r7 ^
) K7 H# u5 K9 O8 T" N/ r
& P0 O! q5 O. P& z+ n' R* m8 L* v# [# q, e2 R9 T7 H/ R
; F+ h$ }) ^; u z: }
2 A8 o& D) ]5 L/ @" A6 S
3 K4 O1 a% l1 s; B, y7 @8 J3 c
. C- i3 Z2 v, u0 ?; n; c$ A _0 a( | F) D
# Q# p# N* J( a7 S% p( P) S
8 A, x% L& {2 U X; d ^
) M- e4 U9 o5 {8 [" c5 T6 v提示语法错误,数据并没有成功保存。 这让我想起了之前看到过的一篇文章,说eval执行的时候对参数的长度是有限制的,而我现在用的一句话木马连接客户端用了2个参数,虽然我已经尽量把第二个参数简单化了,但是貌似还是超出长度了。 下面来试试execute:9 D) z% w" a+ e4 Z8 k$ d/ ]
8 u& _0 d- @. E3 p
7 x3 w# I2 B9 H2 {- w3 v5 Z+ B, @7 |, @
0 O" s2 ?+ _% B' Z* r$ p0 [+ z0 b
结果我发现单击“提交”按钮时页面没有反应,我换了opera浏览器来运行一句话客户端,发现大马被提交了一部分,但并没有完全被写入:
2 i6 R: @6 h+ I( N: G6 S' h3 }, u0 U& F" i
( {4 M3 [0 l2 n# d [5 Z' B
. o) T k7 i) \( d- a
& C j" a' p3 F% s. z Y7 _2 u; }$ N
9 e+ u* U& |; S# o( k. q; N $ z* j# c. S: a. I$ s! L$ ?
看来数据量还是太大了。 那么这个时候,来提交个ASP的下载脚本试
4 ]) }* @" H; T! c$ S3 M3 g. n9 A" W3 ~! C6 X+ T9 m
8 x% e+ E) @4 u+ N3 A/ v, }
$ k9 I, @$ r+ T; ~8 G# M
& n6 C4 L \' f5 J; s) T4 _5 [" R! Y7 q9 O3 H- S+ a6 M
结果表明:完全没有问题。 至此,遇到的不能POST的限制完美突破,虽然麻烦点。 |