重构后的Firefox网络监视工具,里边加了什么黑科技?

简介: 本文讲的是重构后的Firefox网络监视工具,里边加了什么黑科技?,Firefox开发工具的早期版本已经在Firefox中提供了网络监视器工具,任何关心页面加载性能和网页运行速度的用户都非常喜欢这个工具。
本文讲的是 重构后的Firefox网络监视工具,里边加了什么黑科技?

重构后的Firefox网络监视工具,里边加了什么黑科技?

Firefox开发工具的早期版本已经在Firefox中提供了网络监视器工具,任何关心页面加载性能和网页运行速度的用户都非常喜欢这个工具。不过该工具最近被进行了广泛的重构(项目代号为Netmonitor.html),这篇文章旨在向大家解释如何设计新架构以及你如何使用重构之后的新技术。

以下就是Firefox Developer Toolbox中运行的网络监视器用户界面。

重构后的Firefox网络监视工具,里边加了什么黑科技?

目标

重构的主要目标之一是在标准Web技术之上重建整个工具,开发人员删除了所有特定于Firefox的旧版代码,如XUL(XML用户界面语言),还有使用特定于Firefox的API的代码。这是一个很大的进步,因为使用网络标准可以允许你在两个不同的环境中运行整个工具的代码库:

1.开发工具箱

2.任何网页

任何熟悉Firefox开发工具的人都知道第一种情况,开发者工具箱可以在浏览器窗口的底部轻松打开,并附带各种工具(包括网络监视器)。

第二个工具是新的,现在可以像任何其他标准Web应用程序一样在浏览器选项卡中加载该工具,以下就是其界面外观。

重构后的Firefox网络监视工具,里边加了什么黑科技?

请注意,该页面是从localhost:8000加载的,这是开发服务器正在运行的位置。

将工具作为网络应用程序运行的能力是一件很重要的突破,现在你可以使用所有的浏览器工具来开发工作流。虽然可以使用DevTools来调试DevTools,但使用浏览器中的工具会让调试现在变得更加简单和方便。当然,你也可以在其他浏览器中加载该工具。开发也更简单,

因为我们不必构建Firefox。总而言之,一个简单的标签刷新就足以让网络监视器重新加载并测试代码更改。

架构

我们已经在以下技术的基础上构建了新的网络监视器前端:

React
Redux
Immutable
Mocha
Enzyme
Webpack
Yarn

Firefox Developer Tools需要复杂的UI属性,所以开发人员会使用受欢迎的React和Redux组合来为所有的工具建立一个简洁而一致的代码库,网络监视器也不例外。目前开发人员已经实现了一组React组件,它们负责渲染UI,起到存储的作用,通过HTTP拦截收集所有数据,最后是一组用户可能要执行的操作。

开发人员也改变了以前编写测试的方式,不再使用Firefox特定的测试工具,而是慢慢转向比较广泛使用的库,如Mocha 和 Enzyme。这样一来,就更容易理解新的代码库。

开发人员正在使用Webpack在网页中运行时构建捆绑包,捆绑包会通过localhost:8000服务。

一般架构基于React和Redux概念中引入的流程。

重构后的Firefox网络监视工具,里边加了什么黑科技?

1.表示NetMonitorApp的根组件可以在Developer Toolbox或Web页面中呈现。

2.操作负责过滤,清除请求列表,排序和打开具有详细信息的侧面板。

3.我们的所有数据都存储在存储对象中,包括有关HTTP流量的所有收集的数据。

新功能

我们一直主要关注代码重构,但是还有一些新功能或 UI方面的改进。我们来看看其中的一些。

Column Picker

有一些列包含有关个别请求的附加信息,用户可以使用上下文菜单来选择那些认为重要的信息。

重构后的Firefox网络监视工具,里边加了什么黑科技?

总计数据(Summary Data)

研究人员已经为列表中当前显示的请求实现了更好的总计,它现在位于面板的底部。

重构后的Firefox网络监视工具,里边加了什么黑科技?

列表中的请求数

所有请求的大小或传送大小

加载所有请求所需的总时间

发生DomContentLoaded事件的时间

加载事件发生的时间

过滤性能(Filtering By Properties)

过滤器UI现在更强大了,可以根据各种属性过滤请求列表。例如,你可以在过滤器输入框中键入:greater-than:50,只查看大于50个字节的请求。

重构后的Firefox网络监视工具,里边加了什么黑科技?

了解更多MDN

指向MDN的UI中有许多地方有更多信息的链接。例如,您可以快速了解各种HTTP标头的使用方式。点击这里,了解更多的MDN

重构后的Firefox网络监视工具,里边加了什么黑科技?

总结

我们相信,根据Web标准构建新一代Firefox Developer Tools是正确的方式,因为这意味着工具可以在不同环境中运行,并且可以更有效地与其他项目(例如IDE)集成。 以网络标准为基础的工具会使许多事情成为可能,现在你还可以考虑将该工具作为可以从互联网平台中受益的在线Web服务。 你可以在网络上分享收集的数据以及调试上下文,打开一个真正的社交调试世界的大门。




原文发布时间为:2017年6月24日
本文作者:xiaohui 
本文来自云栖社区合作伙伴嘶吼,了解相关信息可以关注嘶吼网站。
目录
相关文章
|
8天前
|
数据采集 人工智能 自然语言处理
FireCrawl:开源 AI 网络爬虫工具,自动爬取网站及子页面内容,预处理为结构化数据
FireCrawl 是一款开源的 AI 网络爬虫工具,专为处理动态网页内容、自动爬取网站及子页面而设计,支持多种数据提取和输出格式。
66 18
FireCrawl:开源 AI 网络爬虫工具,自动爬取网站及子页面内容,预处理为结构化数据
|
16天前
|
存储 安全 物联网
浅析Kismet:无线网络监测与分析工具
Kismet是一款开源的无线网络监测和入侵检测系统(IDS),支持Wi-Fi、Bluetooth、ZigBee等协议,具备被动监听、实时数据分析、地理定位等功能。广泛应用于安全审计、网络优化和频谱管理。本文介绍其安装配置、基本操作及高级应用技巧,帮助用户掌握这一强大的无线网络安全工具。
44 9
浅析Kismet:无线网络监测与分析工具
|
2天前
|
网络协议 安全 测试技术
Nping工具详解:网络工程师的瑞士军刀
### Nping工具详解:网络工程师的瑞士军刀 Nping是Nmap项目的一部分,支持TCP、UDP、ICMP和ARP等多种协议,用于生成和分析网络数据包。它提供灵活的命令行界面,适用于网络探测、安全测试和故障排除。本文介绍Nping的基础与高级用法,包括发送不同类型的网络请求、自定义TCP标志位、路由跟踪等,并通过实战案例展示其应用。掌握Nping有助于更好地理解和管理网络环境。 (239字符)
31 8
|
2月前
|
安全 Windows
【Azure Cloud Service】在Windows系统中抓取网络包 ( 不需要另外安全抓包工具)
通常,在生产环境中,为了保证系统环境的安全和纯粹,是不建议安装其它软件或排查工具(如果可以安装,也是需要走审批流程)。 本文将介绍一种,不用安装Wireshark / tcpdump 等工具,使用Windows系统自带的 netsh trace 命令来获取网络包的步骤
82 32
|
2月前
|
安全 网络安全 数据安全/隐私保护
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。ACL 可应用于路由器、防火墙等设备,通过设定规则控制访问。其类型包括标准、扩展、基于时间和基于用户的ACL,广泛用于企业网络和互联网安全中,以增强安全性、实现精细管理和灵活调整。然而,ACL 也存在管理复杂和可能影响性能的局限性。未来,ACL 将趋向智能化和自动化,与其他安全技术结合,提供更全面的安全保障。
135 4
|
2月前
|
存储 网络协议 定位技术
OSPF路由汇总:优化网络的强大工具
OSPF路由汇总:优化网络的强大工具
76 1
|
2月前
|
安全 Linux 网络安全
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息。本文分三部分介绍 nmap:基本原理、使用方法及技巧、实际应用及案例分析。通过学习 nmap,您可以更好地了解网络拓扑和安全状况,提升网络安全管理和渗透测试能力。
198 5
|
3月前
|
网络协议 安全 Linux
网络工具ping的使用方式
【10月更文挑战第19天】网络工具ping的使用方式
176 6
|
4月前
|
监控 网络协议 安全
远程网络监视RMON和RMON2有啥区别?
【9月更文挑战第2天】
91 4
远程网络监视RMON和RMON2有啥区别?
|
5月前
|
Kubernetes 监控 Shell
在K8S中,我们公司用户反应pod连接数非常多,希望看一下这些连接都是什么信息?什么状态?怎么排查?容器里面没有集成bash环境、网络工具,怎么处理?
在K8S中,我们公司用户反应pod连接数非常多,希望看一下这些连接都是什么信息?什么状态?怎么排查?容器里面没有集成bash环境、网络工具,怎么处理?