`

Python和MD5网站挂马检测程序

 
阅读更多
系统管理员通常从svn/git中检索代码,部署站点后通常首先会生成该站点所有文件的MD5值,如果上线后网站页面内容被篡改(如挂马)等,可以比对之前生成MD5值快速查找去那些文件被更改,为了使系统管理员第一时间发现,可结合crontab或nagios等工具。

分享一例python结合md5检测网站挂马的程序代码。


一、程序测试
# python check_change.py
Usage: python check_change.py update /home/wwwroot
python check_change.py check /home/wwwroot
# python check_change.py update /data/www #生成站点的md5值
# echo ' ' > /data/www/sitemap.html #测试清空文件
# rm -rf /data/www/sitemap.xml #测试删除文件
# python check_change.py check /data/www  #查找那些文件被篡改
/data/www/sitemap.xml
/data/www/sitemap.html


二、实现代码(check_change.py)
#!/usr/bin/env python
# www.jbxue.com
import os,sys,subprocess
def update(path):
    f = open(file,'w')
    for root,dirs,files in os.walk(path):
        for name in files:
            line = os.path.join(root, name)
            (stdin,stderr) = subprocess.Popen(['md5sum',line],stdout=subprocess.PIPE).communicate()
            f.write(stdin)
    f.close()
def check(path):
    f = open(file,'r')
    for line in f:
        check_ok = """echo '%s' | md5sum -c > /dev/null 2>&1""" % line
        #print check_ok
        if not subprocess.call(check_ok, shell = True) == 0:
            abnormal = line.split()
            print abnormal[1]
    f.close()
def Usage():
    print '''
    Usage: python %s update /home/wwwroot
           python %s check /home/wwwroot
    ''' % (sys.argv[0],sys.argv[0])
    sys.exit()
if len(sys.argv) != 3:
    Usage()
file = 'file.key'
model = sys.argv[1]
path = sys.argv[2]
if os.path.exists(path) == False:
    print "\033[;31mThe directory or file does not exist\033[0m"
    sys.exit()
elif model == 'update':
    update(path)
elif model == 'check':
    check(path)
else:
    Usage()
分享到:
评论

相关推荐

    python进行MD5加密源码.zip

    6. **文件的MD5校验**:除了对字符串进行MD5加密,我们还可以计算文件的MD5值,这在验证文件完整性和一致性时非常有用。以下是如何计算文件的MD5值: ```python def calculate_file_md5(file_path): with open...

    Python 如何使用MD5或SHA1等算法对用户密码进行加密 Python源码

    Python 如何使用MD5或SHA1等算法对用户密码进行加密 Python源码Python 如何...Python源码Python 如何使用MD5或SHA1等算法对用户密码进行加密 Python源码Python 如何使用MD5或SHA1等算法对用户密码进行加密 Python源码

    md5碰撞爆破python3脚本

    md5碰撞爆破python3脚本

    基于python实现MD5加密窗体程序

    基于python实现MD5加密窗体程序

    Python实现的检测网站挂马程序

    系统管理员通常从svn/git中检索代码,部署站点后通常首先会生成该站点所有文件的MD5值,如果上线后网站页面内容被篡改(如挂马)等,可以比对之前生成MD5值快速查找去那些文件被更改,为了使系统管理员第一时间发现...

    通过python获取依赖以及MD5

    通过python获取程序依赖以及MD5

    Python+md5加密

    在这个“Python+md5加密”的主题中,我们将探讨如何使用Python来实现MD5加密。 MD5的基本原理是,它接收任意长度的信息,通过一系列复杂的数学和位操作,将其转化为128位的摘要,通常以32位十六进制数字的形式展示...

    python写一个md5解密器示例

    md5解密,百度了一下发现教程不是很多也不详细。 这个图都没一张。。。 0x01 windows环境,kali也可以啊 burpsuite requests模块 bs4模块 0x02: 设置好代理 开启burpsuite (我这是新版的burp) 这代表设置好了...

    md5碰撞爆破python2脚本

    md5碰撞爆破python2脚本

    python实现md5以及rsa加密方式

    python3简单实现rsa以及MD5加密方式,内有自己写的详细注释

    PYTHON学习教程md格式

    Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。 Python 的设计具有很强的可读性,相比其他语言经常使用英文关键字,其他语言的一些标点符号,它具有比其他语言更有特色语法结构。 * *...

    python2实现md5加密文件

    用python2实现的md5加密文件功能,pycharm运行即可,也可加密字符串(需改代码)

    01.初识Python.md

    01.初识Python.md

    python3 hashlib md5

    这是一个关于python哈希值的md5系列函数,版本为python3.7.x,导入库名为hashlib的md5示例代码

    01 初始Python.md

    01 初始Python.md

    yolov5摔倒检测openpose跌倒检测python源码可检测视频可检测图片

    yolov5摔倒检测openpose跌倒检测python源码可检测视频可检测图片 显示有yolov5进行人体目标检测,再使用openpose进行跌倒检查 效果视频:https://www.bilibili.com/video/BV17D4y1M7pV/

    椭圆检测_python椭圆检测_

    5. 峰值检测:确定参数空间中的局部最大值,它们代表可能的椭圆中心和半径。 6. 后处理:通过去除噪声、合并相邻椭圆等步骤,进一步优化结果。 在提供的文件列表中,我们可以看到几个MATLAB文件(tuoyuan2.m、ezh.m...

    MD5批量图片修改程序

    2. MD5计算:Python标准库中的`hashlib`模块提供了MD5哈希函数,程序会先计算原始图片的MD5值,作为比较的基准。 3. 图片处理:为了改变MD5值,程序可能采取的方法是对图片进行微小的无损或有损操作,比如添加像素...

    Python基础.md

    Python基础.md

    Python-02-Python入门.md

    Python-02-Python入门.md

Global site tag (gtag.js) - Google Analytics