|
|
服务器被挂马或被黑的朋友应该知道,黑客入侵web服务器的第一目标是往服务器上上传一个webshell,有了webshell黑客就可以干更多的事情。网站被挂马后很多人会束手无策,无从查起,其实并不复杂,这里我将以php环境为例讲几个小技巧,希望对大家有帮助。4 E/ ^/ |/ [) a" H1 t( y
; E) \% x7 z% ^8 w; L3 n
先讲一下思路,如果服务器上被上传了webshell那么我们肯定能够查到蛛丝马迹,比如php文件的时间,如果我们可以查找最后一次网站代码更新以后的所有php文件,方法如下。
5 V! @% B2 x" Y" ?7 p假设最后更新是10天前,我们可以查找10天内生成的可以php文件:! D) e2 R G2 s; b" z
3 o( x0 v2 @8 Efind /var/webroot -name “*.php” -mtime -10
; i1 u2 \. M, N0 a& Y/ _ : s ]0 \2 n0 B' P! U
命令说明:
9 y% J8 l9 {8 U6 o$ _0 o/var/webroot为网站根目录9 f8 @" I( b2 X+ w
-name “*.php”为查找所有www.2cto.com php文件. H' h; k& d' X( R) ]% r H8 O7 Z' N
-time -10为截止到现在10天
2 L( O/ q9 B) ~, B/ I
$ t& C( B" w2 t, S如果文件更新时间不确定,我们可以通过查找关键字的方法来确定。要想查的准确需要熟悉webshell常用的关键字,我这里列出一些常用的,其他的大家可以从网收集一些webshell,总结自己的关键字,括号里面我总结的一些关键字(eval,shell_exec,passthru,popen,system)查找方法如下:" B8 H2 H( e4 f
; j5 C5 h0 Z, B% F) G2 R' D
find /var/webroot -name “*.php” |xargs grep “eval” |more
/ C: a' ?) N1 }/ W1 Qfind /var/webroot -name “*.php” |xargs grep “shell_exec” |more# B" d5 k R& Z h
find /var/webroot -name “*.php” |xargs grep “passthru” |more5 [. `" ` K9 u3 R
4 y0 [ M5 k* ^+ D8 J% x" q, N
当然你还可以导出到文件,下载下来慢慢分析:
4 @9 Z# R$ B& m$ H! m! R , d, ^0 t8 _, B4 G! `3 T, E
find /home -name “*.php”|xargs grep “fsockopen”|more >test.log
$ s" H$ u( J4 Y( W ! _( z4 b+ N7 F; Q
这里我就不一一罗列了,如果有自己总结的关键字直接替换就可以。当然并不是所有的找出的文件都是webshell需要自己做一下判断,判断的方法也简单,直接从浏览器访问一下这个文件或者和自己找的一些webshell比较一下,看得多了,基本上一眼就可以判断是不是webshell文件。
! G- o- u8 U) G$ [( h |
|