【Android】如何抓取 Android 设备的 UDP/TCP 数据包?

article/2025/8/3 4:19:02

目录

    • 前言
    • 理解抓包
    • tcpdump 实时抓包
    • Wireshark 解包
    • 抓包后的一些思考

前言

在真正接触 UDP/TCP 抓包之前,我一直以为这是一项高深莫测的技术。可当我们真正了解之后才发现,其实并没有那么复杂——不过如此。

所谓的大佬,往往只是掌握了你尚未涉足的知识。而当你掌握了他们未曾触及的领域,你同样也能成为那个受人瞩目的“技术大佬”。

本文将带你了解如何抓取 Android 设备上的 UDP 数据包。跟我一起,迈出成为技术大佬的一步。

理解抓包

抓包(Packet Capture)就是指截取在网络中传输的数据包,用来查看、分析通信内容的过程。

抓包几乎可以抓取所有基于网络传输协议的数据包,包括但不限于:HTTP/HTTPS、FTP、WebSocket、MQTT、TCP、UDP等等。

tcpdump 实时抓包

在本文中,抓包分为两个大步骤,分别为 tcpdump 实时抓包与 Wireshark 解析数据包。tcpdumpLinux 系统内核的一个命令行工具,基于 Linux 内核的 Android 也可以像使用 Linux 那样去使用该指令。

  • 执行 tcpdump 指令前需要进入 Android 系统的 shell 状态
adb -s 设备ip\id shell
  • 通过 su 指令切换至root状态(非root设备无法使用该指令)
su
  • 开始抓包
tcpdump -i any 数据类型 -w /sdcard/udp.pcap

数据类型:根据个人需求,可选 udptcp,不填则默认抓取全部数据包。

  • 停止抓包后将文件保存至电脑
adb -s 设备ip/id pull /sdcard/udp.pcap 电脑路径

Wireshark 解包

👉 点击前往下载 Wireshark

提取抓包文件到电脑后,将 .pcap 后缀名的文件使用 Wireshark 打开,打开后如图:

在这里插入图片描述

接着在顶部的过滤器过滤指定端口的数据,这样就可以看到我们抓取的 UDP 数据。

在这里插入图片描述

如果你想要过滤的数据是 HTTP、MQTT 数据,可以直接在 过滤器输入 http、mqtt

在这里插入图片描述
这里值得注意的是,在查看 HTTP 的数据时,需要选中某一条 HTTP 数据右键 👉 追踪流 👉 HTTP Stream 才能解析出所有的信息。

在这里插入图片描述

抓包后的一些思考

随着抓包工具的普及,网络数据拦截的技术门槛显著降低,数据传输面临的安全威胁日益严峻。要有效应对这一挑战,核心在于实施通信加密——即使数据被截获,攻击者也无法破解其真实内容。

需明确的是,抓包(Packet Capture)作为网络通信的基础行为,本质上无法彻底杜绝。但通过合理的技术手段,可以大幅提高攻击者的破解难度和成本,确保被捕获的数据包无法被有效利用。以下是具体防护策略与使用对应防护措施的工具/技术:

协议防护措施类似工具/技术
UDPDTLS、QUIC、自定义加密OpenSSL, NaCl
MQTTMQTT over TLS、ACL、VPCMosquitto, EMQX
HTTPHTTPS、HSTS、API 签名Nginx, Let’s Encrypt
通用VPN、零信任、流量混淆WireGuard, IPSec

以上就是针对抓包风险的防护措施总结,希望能为您的数据安全防护提供有效参考。通过合理的加密策略和协议优化,可以显著降低敏感信息泄露的风险。

参考文档
1、Wireshark 使用指南 — 官方文档
2、Wireshark 使用指南 — 哔哩哔哩大学
3、Wireshark的抓包和分析,看这篇就够了


http://www.hkcw.cn/article/VQhWpDEyTw.shtml

相关文章

VR看房系统,新生代看房新体验

VR看房系统的概念 虚拟现实(VirtualReality,VR)看房系统,是近年来随着科技进步在房地产行业中兴起的一种创新看房方式。看房系统利用先进的计算机技术模拟出一个三维环境,使用户能够身临其境地浏览和体验房源,无需亲自…

机器学习Day5-模型诊断

实现机器学习算法的技巧。当我们训练模型或使用模型时,发现预测误差很 大,可以考虑进行以下优化: (1)获取更多的训练样本 (2)使用更少的特征 (3)获取其他特征 &#xff…

STM32F103_Bootloader程序开发06 - IAP升级用的App.bin增加CRC32校验码,确保固件完整性,防止“变砖”

导言 《STM32F103_Bootloader程序开发05 - Keil修改生成文件的路径与文件名,自动生成bin格式文件》上一章节成功让Keil生成App.bin二进制文件,用于IAP升级。 为了保障IAP升级过程中的固件完整性,避免因损坏文件导致设备“变砖”,…

语言使用的国家概况统计

语言是文化的载体,也是沟通和协作的桥梁。随着全球化进程加快,了解主要语言的分布及其使用国家,对于数据分析师、产品经理、市场人员乃至技术开发者,都极为重要。本文将梳理全球几种主要语言(英语、法语、阿拉伯语、俄…

DeepSeek-R1-0528

深度思考能力强化​ DeepSeek-R1-0528 仍然使用 2024 年 12 月所发布的 DeepSeek V3 Base 模型作为基座,但在后训练过程中投入了更多算力,显著提升了模型的思维深度与推理能力。 更新后的 R1 模型在数学、编程与通用逻辑等多个基准测评中取得了当前国内…

MCU STM32搭配存储SD NAND(贴片式T卡)于智能皮电手环(Galvanic Skin Response, GSR 手环)的全方位评测

文章目录 卓越性能强化安全高效能效图形处理优势丰富集成特性模拟模块实时监控保障数据完整性提升安全性与可靠性测量原理采样率相关 在智能皮电手环及数据存储技术不断迭代的当下,主控 MCU STM32H750 与存储 SD NAND MKDV4GIL-AST 的强强联合,正引领行业…

处理知识库文件_编写powershell脚本文件_批量转换其他格式文件到pdf文件---人工智能工作笔记0249

最近在做部门知识库,选用的dify,作为rag的工具,但是经过多个对比,最后发现, 比较好用的是,纳米搜索,但是可惜纳米搜索无法在内网使用,无法把知识库放到本地,导致 有信息…

Java 基础 常见知识

基本数据类型 Java 中基本数据类型?对应的包装类?占多少字节? Java 中有 8 种基本数据类型: 6 种数字类型: 4 种整数类型:byte、short、int、long2 种浮点类型:float、double 1 种字符类型&a…

直播预告 | 聚焦芯必达|打造可靠高效的国产 MCU 与智能 SBC 汽车解决方案

随着汽车电子国产化快速推进,车规级 MCU 与 CAN/LIN SBC 作为车身控制的核心组件,正面临更高的安全与可靠性挑战。品佳集团将携手芯必达微电子,深入剖析国产 MCU/SBC/智能 SBC 的最新技术与应用,助力企业打造高性能、可量产的国产…

TF 卡 U1 与 U3 的核心差异解析:从速度标准到应用场景

在选购 TF 卡时,常常会看到 U1、U3 等标识,这些标识代表着不同的性能等级。最近不少客户询问 TF 卡 U1 和 U3 的区别,接下来将从多个维度为您详细解读,并通过对比图表直观呈现差异。 对比项目U1U3速度标准最低写入速度 10MB/s最低…

【Linux】vim编辑器

前言: 上文我们讲到了Linux中权限相关的指令【Linux】权限相关指令-CSDN博客 本文来讲解以下能让我们在Linux下编写代码的工具:vim 1.vim简单介绍 vim是Linux中一个较为常用的编辑器,也是Linux中上手难度最大的编辑器之一。有的同学可能知道v…

PKC6100A电流探头:攻克800V高压测试新利器

在新能源汽车行业快速发展的今天,电机控制器作为电动车辆的"大脑",其性能测试至关重要。然而,传统测试设备往往难以满足高压平台下的严苛测试需求。本文将为您揭秘普科科技PKC6100A电流探头如何帮助行业领先企业攻克测试难关。 一、…

【C++】STL详解(四)---Stack和Queue

文章目录 Stack定义方式使用方式 Queue定义方式使用方式 Stack Stack是一种容器&#xff0c;是基本的数据结构之一&#xff0c;特点是先进后出。 定义方式 方式一&#xff1a;普通定义方式 stack<int> st1;方式二&#xff1a; stack<int,vector<int>> …

换宽带ip地址会变吗?同一个宽带如何切换ip地址

在当今互联网时代&#xff0c;IP地址作为网络设备的"身份证"&#xff0c;其重要性不言而喻。许多用户在使用宽带时都会遇到这样的疑问&#xff1a;换宽带IP地址会变吗&#xff1f;同一个宽带如何切换IP地址&#xff1f;本文将深入探讨这一问题&#xff0c;帮助读者全…

WPF中一种使用Geometry图标的方法,用作制作图标按钮

1.去阿里巴巴矢量图标库或者哪里的图标库找到svg代码&#xff1a; 2.粘贴看一下&#xff1a; 3.摘取其中path属性&#xff0c;创建Geometry对象&#xff1a; 4.然后可以在按钮中使用&#xff1a; 感觉东西太多了&#xff0c;学不玩了

第二代IndoorLink头戴式无线讲解器,远距+动感,更好用了

在讲解器市场中&#xff0c;IndoorLink&#xff08;音德聆客&#xff09;头戴式无线讲解器一直具有鲜明的辨识度&#xff0c;张扬个性、动感自由的特点&#xff0c;受到很多用户欢迎。经过近一年的精细打磨后&#xff0c;IndoorLink头戴式迎来了全新升级。 日前&#xff0c;深…

PYTHON通过VOSK实现离线听写支持WINDOWSLinux_X86架构

在当今人工智能快速发展的时代&#xff0c;语音识别技术已经成为人机交互的重要方式之一。本文将介绍如何使用Python结合Vosk和PyAudio库实现一个离线语音识别系统&#xff0c;无需依赖网络连接即可完成语音转文字的功能。 技术栈概述 1. Vosk语音识别引擎 Vosk是一个开源的…

MyBatisPlus--快速入门

MyBatisPlus介绍 从名字中就可以感觉到MybatisPlus与MyBatis之间的渊源&#xff0c;而MyBatis是一个非常流行的持久层框架&#xff0c;主要来做数据库的增删改查&#xff0c;而MyBatisPlus这种命名方式让人不得不往MyBatis的升级版去联想&#xff0c;事实也确实如此&#xff0…

STL_stack和queue(deque priority_queue)

前言 本文主要介绍&#xff0c;本人的学习心得和知识汇总&#xff0c;本篇博文对于STL知识的讲解侧重于难点&#xff0c;不会每一个都细细讲解。本文主要对适配器设计模式展开讲解&#xff0c;对反向迭代器和优先级队列重点讲解。STL对栈和队列的设计不同于之前c语言设计的栈和…