python:一个代理流量监控的媒体文件下载脚本

前言

一个mitmproxy代理服务应用,作用是监听系统流量,并自动下载可能的video媒体文件到本地。

如果你没有安装mitmproxy或没有做完准备工作,请参考我的这篇文章:

python:mitmproxy代理服务搭建-CSDN博客

文件架构目录

源码

python 复制代码
import os
import time
import threading
import requests
from mitmproxy import http

SAME_DOWNLOADS = []

# 设置代理
proxies = {
    'http': 'http://127.0.0.1:9099',
    'https': 'http://127.0.0.1:9099'
}


def go_download(url, save_path):
    if url in SAME_DOWNLOADS:
        return
    SAME_DOWNLOADS.append(url)
    r = requests.get(url, proxies=proxies, verify=False)
    with open(save_path, 'wb') as f:
        f.write(r.content)
    print(save_path, 'saved')


# 定义资源类型分类函数
def classify_resource(flow: http.HTTPFlow):
    url = flow.request.url
    content_type = flow.response.headers.get('Content-Type', '')

    # 媒体资源
    if any(ext in url for ext in ['.mp4', '.avi', '.mov', '.mkv', '.mp3', '.wav']):
        extensions = ['.mp4', '.avi', '.mov', '.mkv', '.mp3', '.wav']
        for ext in extensions:
            if ext in url:
                filename = str(int(time.time()) * 1000) + ext
                print(filename, 'downloading')
                a = threading.Thread(target=go_download, args=(url, os.path.join('save/video', filename)))
                a.start()
                break

        return '媒体资源'
    elif 'video/' in content_type or 'audio/' in content_type:
        filename = str(int(time.time()) * 1000) + '.' + content_type.split('/')[-1]
        print(filename, 'downloading')
        a = threading.Thread(target=go_download, args=(url, os.path.join('save/video', filename)))
        a.start()
        return '媒体资源'

    # 图片资源
    if any(ext in url for ext in ['.jpg', '.jpeg', '.png', '.gif', '.bmp']):
        return '图片资源'
    elif 'image/' in content_type:
        return '图片资源'

    # 页面资源
    if 'text/html' in content_type:
        return '页面资源'

    # CSS 资源
    if any(ext in url for ext in ['.css']):
        return 'CSS 资源'
    elif 'text/css' in content_type:
        return 'CSS 资源'

    # JS 资源
    if any(ext in url for ext in ['.js']):
        return 'JS 资源'
    elif 'application/javascript' in content_type:
        return 'JS 资源'

    # API 接口资源
    if '/api/' in url.lower() or 'application/json' in content_type:
        return 'API 接口资源'

    return '其他资源'


# 请求处理函数
def response(flow: http.HTTPFlow) -> None:
    if flow.response:
        resource_type = classify_resource(flow)
        print(f"URL: {flow.request.url}")
        print(f"Resource Type: {resource_type}")
        print("-" * 50)
        # 将资源类型添加到请求的注释中
        flow.request.comment = resource_type

运行指令:

python 复制代码
mitmdump -s simply_run.py -p 9099

结果展示:

相关推荐
飞翔的佩奇2 小时前
【完整源码+数据集+部署教程】表盘指针检测系统源码和数据集:改进yolo11-CA-HSFPN
python·yolo·计算机视觉·数据集·yolo11·表盘指针检测
larance2 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
搏博3 小时前
基于Python3.10.6与jieba库的中文分词模型接口在Windows Server 2022上的实现与部署教程
windows·python·自然语言处理·flask·中文分词
麦兜*4 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
lxmyzzs4 小时前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
萧鼎5 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
艾伦~耶格尔6 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
yujkss6 小时前
Python脚本每天爬取微博热搜-终版
开发语言·python
yzx9910136 小时前
小程序开发APP
开发语言·人工智能·python·yolo
飞翔的佩奇6 小时前
【完整源码+数据集+部署教程】二维码与查找模式检测系统源码和数据集:改进yolo11-CSwinTransformer
python·yolo·计算机视觉·数据集·yolo11·二维码与查找模式检测