学习 Wireshark 分析 Android Netlog

Android 设备抓取的日志中,netlog 文件夹包含.cap文件可以使用Wireshark工具查看网络日志。

Wireshark 分析 DNS 步骤

在使用Wireshark分析网路日志时,要检查DNS解析是否正常,可以按照以下步骤操作:

识别DNS查询和回应

  • 使用过滤器 udp.port == 53 来查看所有DNS相关的流量,因为DNS通常基于UDP协议的53端口(除非有特殊配置使用TCP)。

检查DNS响应

  • 查看DNS响应包,确保状态码(Status Code)为NoError(0)。这意味着查询成功,没有错误。
  • 在响应中,你应该能看到对应的Answer部分,列出解析出的A记录(IPv4地址)或其他记录类型(如AAAA、CNAME等)。

测试域名解析

  • 如果需要查看特定域名的解析情况,可以使用过滤器。例如:
    dns.qry.name contains "example.com"
    
    这样可以过滤出包含特定域名查询与应答的数据包。

 分析响应时间

  • 在Wireshark数据中,注意观察请求与响应之间的时间差。若响应过慢,可能暗示网络延迟或DNS服务器性能问题。

结果验证

  • 对比应答中的IP地址与预期值,确保解析结果正确。
  • 若发现某些查询无应答或状态码不为NoError,需要查明是解析失败、拒绝,还是超时等原因。

 其他信息

  • CNAME跟随:若有CNAME记录,应确保CNAME能正确转换到最终A或AAAA记录。
  • 缓存检查:若一开始没有看到DNS流量,可以检查是否存在本地缓存效应。

通过这些步骤,你可以判断DNS解析是否正常,并找出潜在的解析问题。如发现持续失败,可能需要检查网络连接、确认使用的DNS服务器是否可用,或调整DNS配置(例如,替换为公共DNS)。

DNS知识

在DNS协议中,OpcodeStatus Code(通常称为Response CodeRcode)是两个不同的概念。

Opcode

  • 定义Opcode字段表示DNS消息的操作码,其值为0表示这是一个标准查询(QUERY)。
  • 作用:指示请求的类型,例如标准查询、反向查询等。在大多数情况下,Opcode为0就是标准查询。

Rcode(Response Code)

  • 定义Rcode字段在DNS响应中,指示查询的结果状态。常见的Rcode包括:
    • 0 (NoError):表示无错误,查询成功。
    • 3 (NXDOMAIN):表示域名不存在。
    • 5 (Refused):表示服务器拒绝执行查询操作。
  • 位置:Rcode通常是在响应消息的Flags中。

一个DNS标准查询
Wireshark-Netlog-一个DNS标准查询

如上显示一个DNS标准查询,而不是查询,因此没有Rcode字段, 

Answer RRs

以下是可能导致Answer RRs为0的原因:

  1. 未接收到相应的响应:你所截图的只是DNS查询,非响应。如果没有对应的响应显示在捕获数据中,意味着可能响应未返回或被丢弃了。

  2. 响应中无答案:如果你查看到的响应包内的Answer RRs为0,而Rcode为0(NoError),则表示查询能够成功执行,但是请求的记录不在服务器的DNS数据库中(例如,查询的子域可能没有配置,结果为空)。

分组解读

DNS Frame
DNS 信息
DNS 分组主要信息分类
分类详情

Frame

包含捕获的字节数量和帧在链接层上的完整信息。这部分一般用于识别数据包在物理/数据链路层的传输细节,例如时间戳之类的信息。

Linux cooked capture v2描述了数据包的封装方式,用于非以太网接口的捕获,显示链路层协议类型、接口索引、链路层地址类型等。
Internet Protocol Version 4 (IPv4)

提供IP相关信息,包括源IP地址(Src: 10.89.31.165)和目标IP地址(Dst: 120.196.165.7)。检查源和目的地址是否符合预期是判断数据包路由正确的重要步骤。

eg:Internet Protocol Version 4, Src:10.89.31.165, Dst:120.196.165.7

User Datagram Protocol (UDP)

显示UDP源端口和目标端口(Src Port: 35148, Dst Port: 53)。端口53是DNS的默认端口。

eg:User Datagram Protocol, Src Port: 35148, Dst Port: 53

Domain Name System(DNS)

- Transaction ID: 识别请求与响应的唯一ID(0xeb8b)。

- Flags: 显示操作码(Opcode: Standard query)和此消息是否为请求或响应。

- Queries: 列出查询信息,包括请求的域名和类型(如A记录),例如查询 connectivitycheck.gstatic.com 的A记录(IPv4地址)。

如何找到响应数据

  • 数据包交互
    • 在Wireshark中,可以通过Transaction ID追踪到相应的DNS响应包。通常在相应的数据包列表中按这一ID进行过滤或查看。
    • 点击[Response In: 7]

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony启动系统-U-Boot简介和源码下载与编译

OpenHarmony系统启动流程简述 设备上电后,OpenHarmony系统大致经历以下3个阶段: 1.BootRom代码引导加载UBoot; 2.UBoot启动初始化硬件资源,引导并加载系统内核(Linux内核); 3.Kernel(LiteOs,Linux内核)启动、加载驱动…

论文笔记-NeurIPS2017-DropoutNet

论文笔记-NeurIPS2017-DropoutNet: Addressing Cold Start in Recommender Systems DropoutNet:解决推荐系统中的冷启动问题摘要1.引言2.前言3.方法3.1模型架构3.2冷启动训练3.3推荐 4.实验4.1实验设置4.2在CiteULike上的实验结果4.2.1 Dropout率的影响4.2.2 实验结…

ctf网络安全赛题

CTF简介 CTF(Capture The Flag)中文一般译作夺旗赛,在网络安全领域中指的是网络安全技术人员之间进行技术竞技的一种比赛形式。CTF起源于1996年DEFCON全球黑客大会,以代替之前黑客们通过互相发起真实攻击进行技术比拼的方式。发展…

一周学会Flask3 Python Web开发-WTForms表单验证

锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 我们可以通过WTForms表单类属性的validators属性来实现表单验证。 常用的WTForms验证器 验证器说明DataRequired(messageNo…

工业巡检进入‘无人化+AI’时代:无人机智能系统的落地实践与未来

在现代化工业生产、建筑设施和交通运输等领域,设备设施的稳定运行是保障安全和效率的核心。传统人工巡检方式受限于效率低、成本高、漏检风险大等问题,已难以满足日益复杂的运维需求。在此背景下,无人机智能巡检系统凭借其高效性、智能化和精…

CentOS 7中安装Dify

Dify 是一个开源的 LLM 应用开发平台。其直观的界面结合了 AI 工作流、RAG 管道、Agent、模型管理、可观测性功能等,让您可以快速从原型到生产。尤其是我们本地部署DeepSeek等大模型时,会需要用到Dify来帮我们快捷的开发和应用。 大家可以参考学习它的中…

Kmeans算法来实现RFM指标计算步骤

K-Means(K均值)是一种经典的无监督聚类算法,主要用于将数据集划分为 KKK 个不同的簇(Cluster)。 它基于最小化簇内样本的平方误差,即最小化数据点与簇中心的距离之和。 1. K-Means 算法原理 (1) 主要步骤 …

C# .NET Core HttpClient 和 HttpWebRequest 使用

HttpWebRequest 这是.NET创建者最初开发用于使用HTTP请求的标准类。HttpWebRequest是老版本.net下常用的,较为底层且复杂,访问速度及并发也不甚理想,但是使用HttpWebRequest可以让开发者控制请求/响应流程的各个方面,如 timeouts,…

run方法执行过程分析

文章目录 run方法核心流程SpringApplicationRunListener监听器监听器的配置与加载SpringApplicationRunListener源码解析实现类EventPublishingRunListener 初始化ApplicationArguments初始化ConfigurableEnvironment获取或创建环境配置环境 打印BannerSpring应用上下文的创建S…

1.从0搭建前端Vue项目工程

我们通过vue官方提供的脚手架Vue-cli来快速生成一个Vue的项目模板。 **注意:**需要先安装NodeJS,然后才能安装Vue-cli。 环境准备好了,接下来我们需要通过Vue-cli创建一个vue项目,然后再学习一下vue项目的目录结构。Vue-cli提供了…

C语言学习笔记-初阶(27)操作符详解1:位操作

1. 操作符的分类 上述的操作符,我们已经学过算术操作符、赋值操作符、逻辑操作符、条件操作符和部分的单目操作符,今天继续介绍⼀部分,操作符中有一些操作符和二进制有关系,我们先铺垫一下二进制的和进制转换的知识。 2. 二进制、…

蓝桥杯备考:动态规划线性dp之传球游戏

按照动态规划的做题顺序 step1&#xff1a;定义状态表示 f[i][j] 表示 第i次传递给了第j号时一共有多少种方案 step2: 推到状压公式 step3:初始化 step4:最终结果实际上就是f[m][1] #include <iostream> #include <cstring> using namespace std;const int N …

FinRobot:一个使用大型语言模型进行金融分析的开源AI代理平台

文章目录 前言一、生态系统1. 金融AI代理&#xff08;Financial AI Agents&#xff09;2. 金融大型语言模型&#xff08;Financial LLMs&#xff09;3. LLMOps4. 数据操作&#xff08;DataOps&#xff09;5. 多源LLM基础模型&#xff08;Multi-Source LLM Foundation Models&am…

基于Windows11的RAGFlow安装方法简介

基于Windows11的RAGFlow安装方法简介 一、下载安装Docker docker 下载地址 https://www.docker.com/ Download Docker Desktop 选择Download for Winodws AMD64下载Docker Desktop Installer.exe 双点击 Docker Desktop Installer.exe 进行安装 测试Docker安装是否成功&#…

uniapp 常用 UI 组件库

1. uView UI 特点&#xff1a; 组件丰富&#xff1a;提供覆盖按钮、表单、图标、表格、导航、图表等场景的内置组件。跨平台支持&#xff1a;兼容 App、H5、小程序等多端。高度可定制&#xff1a;支持主题定制&#xff0c;组件样式灵活。实用工具类&#xff1a;提供时间、数组操…

【四.RAG技术与应用】【12.阿里云百炼应用(下):RAG的云端优化与扩展】

在上一篇文章中,我们聊了如何通过阿里云百炼平台快速搭建一个RAG(检索增强生成)应用,实现文档智能问答、知识库管理等基础能力。今天咱们继续深入,聚焦两个核心问题:如何通过云端技术优化RAG的效果,以及如何扩展RAG的应用边界。文章会穿插实战案例,手把手带你踩坑避雷。…

LabVIEW虚拟频谱分析仪

在电子技术快速发展的今天&#xff0c;频谱分析已成为信号优化与故障诊断的核心手段。传统频谱分析仪虽功能强大&#xff0c;但价格高昂且体积笨重&#xff0c;难以满足现场调试或移动场景的需求。 基于LabVIEW开发的虚拟频谱分析仪通过软件替代硬件功能&#xff0c;显著降低成…

解决各大浏览器中http地址无权限调用麦克风摄像头问题(包括谷歌,Edge,360,火狐)后续会陆续补充

项目场景&#xff1a; 在各大浏览器中http地址调用电脑麦克风摄像头会没有权限&#xff0c;http协议无法使用多媒体设备 原因分析&#xff1a; 为了用户的隐私安全&#xff0c;http协议无法使用多媒体设备。因为像摄像头和麦克风属于可能涉及重大隐私问题的API&#xff0c;ge…

知识图谱科研文献推荐系统vue+django+Neo4j的知识图谱

文章结尾部分有CSDN官方提供的学长 联系方式名片 文章结尾部分有CSDN官方提供的学长 联系方式名片 关注B站&#xff0c;有好处&#xff01; &#x1f4d1; 编号&#xff1a;D030 &#x1f4d1; vuedjangoneo4jmysql 前后端分离架构、图数据库 &#x1f4d1; 文献知识图谱&#…

NModbus 连接到Modbus服务器(Modbus TCP)

1、在项目中通过NuGet添加NModbus&#xff0c;在界面中添加一个Button。 using NModbus.Device; using NModbus; using System.Net.Sockets; using System.Text; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Docu…