设为首页 收藏本站
查看: 478|回复: 0

[经验分享] php网站webshell检查脚本

[复制链接]
发表于 2017-3-24 10:19:40 | 显示全部楼层 |阅读模式
参考了一些别人写的脚本,自己用Python写的一个小脚本,简单实用。学习Python为主。
1、检查你的php文件是否是webshell程序,也可以检查危险的函数。
2、可以检查图片文件,但是可能会有误报。
#!/usr/bin/python
#coding=utf-8
#程序描述:webshell检查工具
#版本:1.0.0
#作者:sapling
#创建日期:2009-12-16
#修改原因:
#修改日期:
#修改者:
#使用方法:
#        输入参数:
#        1、第一个参数为被检查文件夹
#        2、第一个参数后跟要检查的文件后缀名,检查多个后缀以空格分开(默认.php .inc)。
#        example:
#        ./webshellChecker ./
#        ./webshellChecker ./ .gif .jpg

import os,sys
import re,time
from stat import ST_MTIME
ISOTIMEFORMAT = '%Y-%m-%d %X'
keywords = (
(r"eval\(\$\_POST","find php muma!!!"),
(r"(system|shell_exec|exec|popen)","find php exec func!!!"),
)
def checkfile(filename):
try:
fp = open(filename)
except:
print "'%s' file open deny"%filename
else:
contents = fp.read()
mtime = time.strftime(ISOTIMEFORMAT,time.gmtime(os.stat(filename)[ST_MTIME]))
for keyword in keywords:
if re.search(keyword[0],contents,re.I):
log = "%s  |  %s  |  %s"%(filename,mtime,keyword[1])
print log
fp.close()
def check(dirname,exts):
try:
ls = os.listdir(dirname)
except:
print "'%s' dir access deny"%dirname
else:
for item in ls:
temp = os.path.join(dirname,item)
if(os.path.isdir(temp)):
check(temp,exts)
else:
ext = os.path.splitext(temp)[1].lower()
if ext in exts:
checkfile(temp)

if __name__ == "__main__":
print "php webshell checker for python!"
print "by sapling"
print "2009-12-16"
if len(sys.argv)<2:
print """输入参数:
1、被检查文件夹
2、要检查的文件后缀名,检查多个后缀以空格分开(默认.php .inc)。
example:
./webshellChecker ./
./webshellChecker ./ .gif .jpg
"""
else:
dir = sys.argv[1]
exts = ['.php','.inc']
if len(sys.argv)>=3:
exts += sys.argv[2:]
print "Check dir is '%s' | ext is %s"%(dir,exts)
print "Start check"
if os.path.exists(dir):
check(dir,exts)
else:
print "dir: '%s' not exists!"%dir

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-354486-1-1.html 上篇帖子: php 浮点类型取整 下篇帖子: php实现-xml+xsl=html
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表