Qt开发网络嗅探器01

news2024/9/23 7:29:52

引言

随着互联网的快速发展和普及,人们对网络性能、安全和管理的需求日益增
长。在复杂的网络环境中,了解和监控网络中的数据流量、安全事件和性能
问题变得至关重要。为了满足这些需求,网络嗅探器作为一种重要的工具被
广泛应用。
网络嗅探器是一种能够捕获、监视和分析网络数据包的设备或软件。它通过
监听网络上的数据流量,提供了对网络通信的深入洞察。网络嗅探器可以检
测和分析网络中传输的数据包,包括协议信息、源地址、目标地址、数据负
载等,从而帮助管理员理解和解决网络中的各种问题。
在网络管理方面,网络嗅探器可以用于流量监测和统计,帮助管理员了解网
络的使用情况、瓶颈和流量模式。它还可以用于网络故障排查和性能优化,
通过分析网络流量和识别异常情况,帮助管理员快速定位和解决问题。此
外,网络嗅探器还可以用于网络安全监控和入侵检测,帮助管理员发现潜在
的安全漏洞和恶意行为,保护网络免受攻击和数据泄露的威胁。
随着网络嗅探技术的不断发展和改进,网络嗅探器在实际应用中变得更加强
大和灵活。它们可以适应不同类型的网络环境,并提供高级的分析和报告功
能。然而,网络嗅探器的应用也面临着一些挑战,如隐私和安全问题。因
此,正确理解和有效使用网络嗅探器是网络管理和安全领域的重要议题,本
报告将探讨网络嗅探器的实现与使用,为读者提供相关知识和指导。

原理

网络嗅探器的工作原理基于数据包的捕获和分析。它通常位于网络的某个关
键节点上,可以直接访问网络传输的数据流量。以下是网络嗅探器的基本原
理:
捕获数据包:网络嗅探器使用特定的技术和接口,如网络适配器或网络
交换机的监控 端口,捕获数据包:网络嗅探器使用特定的网络接口来捕
获经过网络的数据包。它可 以设置过滤条件,只选择感兴趣的数据包进
行捕获,以减少数据量和提高效率。
解析数据包:捕获到的数据包经过解析,提取出关键的信息。这包括源
地址、目标地址、 协议类型、端口号、数据负载等。解析过程根据不同
的网络协议进行,以确保准确获取 数据包的各个字段。
存储和分析:解析后的数据包可以被存储在网络嗅探器的内部存储器或
外部存储设备 中,以便后续分析和查询。存储的数据包可以用于统计、
故障排查、安全检测等目的。分 析过程可以包括流量统计、协议分布、
网络性能指标等。
报告和可视化:网络嗅探器通常提供报告和可视化功能,将分析结果以
图表、图形或 表格的形式展示给管理员。这样可以更直观地理解网络通
信的模式、异常情况和安全事 件,方便管理员做出相应的决策和措施。
网络嗅探器可以在不干扰正常网络通信的情况下对数据包进行捕获和分
析。它的原理基于对数据包的监听和解析,使管理员能够深入了解网络
流量,发现潜在问题并采取相应的措施。

已有的网络嗅探器

在这里插入图片描述

思路

  1. 获取数据包的包头:获取时间、mac地址、ip地址和端口号等信息。
  2. 获取数据包的内容:将包头过滤之后,就是数据包内容,用16进制打印
    出来即可。

原始套接字是⼀种不同于 SOCK_STREAM 和 SOCK_DGRAM 的套接字,它
实现于系统核⼼。创建⽅式与TCP或UDP差不多,但是功能与 TCP 或者
UDP 类型套接字的功能有很⼤的不同:TCP/UDP 类型的套接字只能够访问
传输层以及传输层以上的数据,因为当 IP 层把数据传递给传输层时,下层的
数据包头已经被丢掉了。⽽原始套接字却可以访问传输层以下的数据,所以
使⽤ raw 套接字你可以实现上⾄应⽤层的数据操作,也可以实现下⾄链路层
的数据操作。

实现步骤

第一步考虑全局变量,提供给所有文件使用,我们建立一对叫recourse
的源文件和头文件

#ifndef RECOURSE_H
#define RECOURSE_H
#define HAVE_REMOT
#include "pcap.h"
#include "protocol.h"
#include <QObject>
extern pcap_if_t *alldevs;
extern pcap_if_t *d;
extern bool isRun;
extern pkg_count *pkgCnt;
extern QList<u_char *> netpkgList;
#endif // RECOURSE_H
#include "recourse.h"
pcap_if_t *alldevs = NULL;
pcap_if_t *d = NULL;
bool isRun = false;
pkg_count *pkgCnt = NULL;
QList<u_char *> netpkgList;

这边着重讲一下全局变量,因为涉及到WinPcap库(以下简称wp)函数
的使用:

extern pcap_if_t *alldevs:wp的类型,指向⼀个存储所有⽹卡的容器
extern pcap_if_t *d:wp的类型,指向⼀个⽹卡的设备
extern bool isRun:程序运⾏标志
extern pkg_count *pkgCnt:IP数据包计数
extern QList<u_char *> netpkgList:IP数据包内容容器

下一节是MainWIndow窗口逻辑

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1938423.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IoTDB 分段查询语句详解:GROUP BY + 时序语义

GROUP BY 查询子句的时序语义展开&#xff0c;IoTDB 支持的分段方式总结&#xff01; 存储的数据通过分析来发挥价值&#xff0c;当一组被存储的数据通过查询得到分析后的结果时&#xff0c;这些数据才真正在数据库中实现了价值闭环。 在关系型数据库中&#xff0c;GROUP BY 子…

微信小程序数组绑定使用案例(二)

一、数组事件绑定&#xff0c;事件传递数据 1.wxml <text>姓名&#xff1a;{{name}} </text> <block wx:for"{{list}}"><button bind:tap"nameClick2" data-name"{{item}}">修改:{{item}}</button> </block&…

【BUG】已解决:xlrd.biffh.XLRDError: Excel xlsx file; not supported

已解决&#xff1a;xlrd.biffh.XLRDError: Excel xlsx file&#xff1b; not supported 目录 已解决&#xff1a;xlrd.biffh.XLRDError: Excel xlsx file&#xff1b; not supported 【常见模块错误】 错误原因 解决办法&#xff1a; 欢迎来到英杰社区https://bbs.csdn.net/…

【学习笔记】无人机系统(UAS)的连接、识别和跟踪(三)-架构模型和概念

引言 3GPP TS 23.256 技术规范&#xff0c;主要定义了3GPP系统对无人机&#xff08;UAV&#xff09;的连接性、身份识别、跟踪及A2X&#xff08;Aircraft-to-Everything&#xff09;服务的支持。 3GPP TS 23.256 技术规范&#xff1a; 【免费】3GPPTS23.256技术报告-无人机系…

Ubuntu 中默认的 root 用户密码

场景&#xff1a;想要切换root用户&#xff0c;发现得输入密码&#xff0c;以为是以前设置过然后一直尝试都是错误【认证失败】最后发现根本没设置过root用户&#xff0c;默认会随机生成root用户的密码&#x1f605; Ubuntu 中默认的 root 密码是随机的&#xff0c;即每次开机都…

Golang | Leetcode Golang题解之第263题丑数

题目&#xff1a; 题解&#xff1a; var factors []int{2, 3, 5}func isUgly(n int) bool {if n < 0 {return false}for _, f : range factors {for n%f 0 {n / f}}return n 1 }

数据结构->线性结构->顺序存储->静态链表

一、思路 链表由节点组成。 1、分析需求&#xff0c;画图&#xff1a; 2、定义学生结构体&#xff0c;包含姓名、年龄、性别和下一个学生的指针&#xff1a; #include <stdio.h> #define N 20// 定义性别枚举类型&#xff0c;固定值&#xff0c;不是男就是女 typedef e…

基于Centos7搭建rsyslog服务器

一、配置rsyslog可接收日志 1、准备新的Centos7环境 2、部署lnmp环境 # 安装扩展源 wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo# 安装扩展源 yum install nginx -y# 安装nginx yum install -y php php-devel php-fpm php-mysql php-co…

JVM:GraalVM

文章目录 一、介绍1、什么是GraalVM&#xff1a;2、GraalVM版本 二、两种使用模式 一、介绍 1、什么是GraalVM&#xff1a; GraalVM是Oracle官方推出的一款高性能JDK&#xff0c;使用它享受比OpenJDK或者OracleJDK更好的性能。GraalVM的官网地址&#xff1a;https://www.graa…

我在高职教STM32——串口通信(4)

大家好,我是老耿,高职青椒一枚,一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次,同行应该都懂的,老师在课堂上教学几乎是没什么成就感的。正因如此,才有了借助 CSDN 平台寻求认同感和成就感的想法。在这里,我准备陆续把自己花了很多心思的教学设计分享…

十年前的老电脑能装win10吗_十年前的老电脑用U盘安装win10教程

十年前的老电脑能装win10吗&#xff1f;十年前的老电脑只要满足win10最低要求的配置都可以安装win10。安装win10方法很多&#xff0c;有一键重装方法、U盘安装、硬盘安装等方式&#xff0c;但最靠谱的方式还是U盘安装。十年前的老电脑用U盘安装win10首先要将u盘制作成u盘启动盘…

Flutter中GetX的用法(超详细使用指南之路由依赖管理篇)

目录 1.前言 2.GetX 依赖管理概述 1.GetX 依赖管理的基本概念 2.与其他依赖管理工具的比较 3. 基础依赖注入 1.Get.put 2.Get.lazyPut 3.Get.putAsync 4.高级依赖注入 1.使用Get.create 2.依赖生命周期管理 5. 参考资料 1.前言 今天这篇博客主要介绍Getx的三大功能…

【AI学习】LLaMA 系列模型的进化(二)

在前面LLaMA 系列模型的进化&#xff08;一&#xff09;中学习了LLama模型的总体进化发展&#xff0c;再来看看其中涉及的一些重要技术。 PreLayerNorm Layer Norm有Pre-LN和Post-LN两种。Layer Normalization&#xff08;LN&#xff09;在Transformer架构中的放置位置对模型…

Java实战中如何使用多线程(线程池)及其为什么使用?

这个话题在入行之前就想过很多次&#xff0c;很多8古文或者你搜索的结果都是告诉你什么提高高并发或者是一些很高大上的话&#xff0c;既没有案例也没有什么公式去证明&#xff0c;但是面试中总是被问到&#xff0c;也没有实战经历&#xff0c;所以面试时一问到多线程的东西就无…

python os库使用教程

os库使用教程 1.创建文件夹os.path.exists&#xff08;&#xff09;检查文件是否存在os.listdir查看文件夹下的所有文件filename.endswith()查看文件列表的png或者txt结尾的所有文件shutil.move移动目标到文件夹 1.创建文件夹 先在盘符里创建一个文件用来演示&#xff0c;我这里…

GPT-LLM

本心、输入输出、结果 文章目录 GPT-LLM前言国际公司AI发展概览国内公司AI发展概览GPT-LLM 编辑 | 简简单单 Online zuozuo 地址 | https://blog.csdn.net/qq_15071263 如果觉得本文对你有帮助,欢迎点赞、收藏、评论 前言 国际公司AI发展概览 公司主要AI贡献与产品特点OpenAI…

【Qt】常用控件 Q widget的enabled属性,geometry属性

Qt是一个实现图形化程序的程序。为了便于我们开发&#xff0c;Qt为我们提供了许多“控件”。我们需要熟悉并掌握这些控件的使用。 一.什么是控件 控件是构成⼀个图形化界⾯的基本要素. 示例一&#xff1a; 像上述⽰例一中的,按钮,列表视图,树形视图,单⾏输⼊框,多⾏输⼊框,滚动…

数据恢复篇:适用于 Android 视频恢复的 6 个工具

在智能手机这个动态的世界里&#xff0c;每一刻都被捕捉并以数字方式存储&#xff0c;丢失珍贵的视频可能是一种令人心碎的经历。不必担心&#xff0c;因为 Android 生态系统提供了大量旨在挽救这些珍贵回忆的视频恢复应用程序。 这些应用程序是强大的工具&#xff0c;旨在挽救…

使用Amazon Web Services Lambda把天气预报推送到微信

最近北京开始下雨&#xff0c;开始和同事打赌几点能够雨停&#xff0c;虽然Iphone已经提供了实时天气&#xff0c;但是还是想用国内的API试试看看是不是更加准确些。 以下是我使用的服务&#xff1a; 地图SDK/APP获取 经纬度彩云天气API 通过地理位置获取天气信息Lambda 作为…

【颜色分类】python刷题记录

目录 刷油漆法 刷油漆法 润到字符串排序算法了。 双指针解法 刷了3次油漆 class Solution:def sortColors(self, nums: List[int]) -> None:"""Do not return anything, modify nums in-place instead."""#双指针解法n0n10nlen(nums)for …