IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 调用wireshark接口(tshark.exe)抓包,实现深度自定义,使用python处理抓包数据 -> 正文阅读

[开发测试]调用wireshark接口(tshark.exe)抓包,实现深度自定义,使用python处理抓包数据

# _*_ coding: utf-8 _*_
"""
Time:     2022/4/14 11:13
Author:   Jyun
Version:  V 0.1
File:     demo.py
Blog:     https://ctrlcv.blog.csdn.net
"""

import datetime
import gzip
import json
import time

import pyshark


class GetPacket:
    def __init__(self, network_name, item_filter):
        """
        :param network_name: 网卡名称
        :param item_filter: 抓包过滤条件/规则同wireshark
        """
        tshark_path = r"D:\Program Files\Wireshark\tshark.exe"  # wireshark安装路径下的tshark.exe
        self.cap = pyshark.LiveCapture(interface=network_name, display_filter=item_filter, tshark_path=tshark_path)
        # self.cap.close()

    def action(self):
        requests_dict = {}
        for pak in self.cap.sniff_continuously():
            try:
                request_in = pak.http.request_in
            except AttributeError:
                requests_dict[pak.frame_info.number] = pak
                continue
            self.parse_http(requests_dict[request_in], pak)
            del requests_dict[request_in]

    def gzip(self, data):
        """ 由于pytshark没有帮我们进行gzip解压缩,所以这里手动判断解压一下
        :param data: 16进制原数据
        :return: 文本数据
        """
        try:
            return gzip.decompress(bytearray.fromhex(data)).decode('utf8')
        except ValueError:
            return data

    # noinspection PyProtectedMember
    def parse_http(self, request, response):
        print('\n', request.http.request_full_uri, request.http.request_method)
        data: dict = {'Request': {}, 'Response': {}}
        for name, value in request.http._all_fields.items():
            if name[:4] == 'http':
                data['Request'][name] = value

        for name, value in response.http._all_fields.items():
            if name[:4] == 'http':
                data['Response'][name] = value
                if name == 'http.file_data':
                    if response.http.get('content_encoding') == 'gzip':  # 如果经过了gzip压缩,则先使用原数据解压再写入
                        data['Response'][name] = self.gzip(response.http.data)
                    if response.http.get('content_type') == "application/json":
                        data['Response'][name] = json.loads(data['Response'][name])

        self.write_file(data)

    def write_file(self, data):
        _time = datetime.datetime.now().strftime(f"%Y%m%d_{int(time.time() // 1000)}")
        with open(f'packet_{_time}.txt', 'a') as f:
            f.write(json.dumps(data, indent=4, ensure_ascii=False))
            f.write('\n')


if __name__ == '__main__':
    gp = GetPacket('VPN6 - VPN Client', 'http')
    gp.action()
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-18 18:12:40  更:2022-04-18 18:14:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 14:55:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码