Network面板
Network面板介绍
网络面板分为5个部分:控制器面板,过滤器面板,概览部分,请求列表以及概要部分。
Controls(控制器):使用这些选项可以控制Network面板的外观和功能。
Filter(过滤器):使用这些选项可以控制在Requests Table中显示哪些资源。按住Command/Ctrl键可以点选多个过滤器。
Overview(概览):此图表显示了资源检索时间的时间线。如果看到多条竖线堆叠在一起,说明这些资源同时被检索。
Requests Table(请求列表):此表格列出了检索的每一个资源。默认情况下,此表格按照时间顺序排序,最早的资源在顶部。点击资源的名称可以显示更多信息,右键点击Timeline以外的任何一个表格标题可以添加或者移除信息列。
Summary(概要):此窗格可以一目了然地知道请求总数,传输的数据量和加载时间。
控制器面板

- 第一个按钮控制浏览器是否抓包,如果为红色表示正在抓包,点击之后变灰色表示停止抓包。
- 第二个按钮表示清除按钮,点击之后会清除请求列表。
- 第三个按钮表示过滤器的打开与关闭按钮,点击这个按钮控制下方过滤器打开还是关闭。
- 第四个按钮表示打开一个检索,用得不多。
- 第五个按钮表示是否要跨页面保存请求列表。☑️上表示保留跨页面请求信息,什么意思呢?就是我打开一个A页面,得到了一个请求列表,我再次访问B页面,C页面…无论是什么页面,只要是同一个窗口,所有的请求列表都会保存。
- 第六个按钮表示是否禁用浏览器缓存。一般来说☑️上,然后每一个请求都会去请求新的资源。
- 第七个按钮表示慢速网络模拟。可以使用slow 3G或offline,可以看到浏览器页面在不同网络环境下的样子。
过滤器

通过点选不同类型比如Ajax,JS,CSS等来过滤不同的请求,同时支持点选多个类型的按钮来在请求列表展示多个类型的请求。
前面Filter过滤框还提供了定制化筛选的功能,可以通过输入一些路由的关键词去搜索,也可以通过类似于正则的方式去搜索。比如:
domain:*.nightteam.cn:表示domain为*.nightteam.cn的请求。
status-code:301:表示状态码为301的请求。
set-cookie-domain:bbs.nightteam.cn:表示进行set-cookie的操作的domain。
请求列表

标题栏里面比较关键的是Initiator这一栏,表示请求是由哪里发起的。Other表示发起者通过动作发起,而不是某一个具体的JS发起。bbs.nightteam.cn是我们通过浏览器地址栏输入地址后回车发起的,所以这里显示other,而其它的请求都是可以找到具体调用的JS文件。通过定位到某一个请求的发起文件,我们可以在该文件中增加断点进行调试,所以这一栏比较重要。
点击某一个具体的请求,可以看到它的请求头信息,响应头信息,预览页面,耗时,Cookie信息等。

选中某一个请求,然后右键选择Copy->Copy as cURL得到该请求的cURL命令。

1 | curl 'https://bbs.nightteam.cn/' \ |
可以直接在类Unix系统的控制台中去执行这个cURL命令,也可以把这个命令导入到PostMan中去执行。具体步骤是:

点击Shift键,然后鼠标悬停在某一个请求上,如果展示绿色背景,表示绿色背景的请求依赖你当前悬停的请求。如果展示红色背景,表示当前悬停的请求依赖红色背景的请求。


Source面板
source面板分为三个部分:文件导航窗口,代码编辑器窗格, 调试窗格。
文件导航窗口:可以对文件目录进行浏览;
编辑器窗格:代码编辑,设置断点;
调试窗格:包含调试所用的常用选项。

文件导航窗格

- page面板
以文件目录形式展示当前页面。包含当前网站的页面,静态资源等。
- FileSystem面板
可以让开发者工具加载本地的文件系统,并且能在编辑框口修改编辑,由此化身IDE。这里做一个示范:
第一步:点击Add folder to workspace

第二步:选择要上传的文件夹

第三步:点击允许,让开发者工具具备读写该文件夹的权限

然后就可以看到我们上传的文件夹以及相关的JS文件了:

我们可对其进行编辑修改,打上断点调试等。
- Overrides面板
Overrides面板可以很容易的将远程资源下载一份在本地,然后可以在开发者工具下进行编辑,并且开发者工具会展示我们编辑后的文件。换句话说,就是直接将一些请求代理到本地的文件中。这里同样做一个演示:
前三步跟FileSystem类似:点击Select folder for overrides
,然后选择本地文件夹,之后点击允许赋予开发者工具读写该文件夹的权限。接着要点击选中Enable Local Overrides
:

然后回到Network面板,点击浏览器刷新按钮刷新当前页面,选中一个我们需要代理到本地的请求,右键选择Save for overrides
:

这时,我们刚才添加的文件夹里面就有了保存的代理请求:

然后我们修改本地的这个文件,比如将这个页面的招聘求职
改为MLGJ求职
:

然后,保存刷新这个页面,就成功的将该请求代理到本地文件:

- Content scripts
chrome插件加载的一些脚本,如果有过chrome浏览器插件开发的经验的话,对这个概念应该会很熟悉。在JS逆向中这个用的不多,后面会有专门的文章介绍chrome浏览器插件开发。
- Snippets
我们都知道,有时候需要调试一行JS代码,会在浏览器的Console控制台上去调试,如果需要在浏览器中调试一个代码片段呢?在Console中一行行的输入执行就显得很麻烦了。这个Snippets就可以帮我们解决这个问题,可以通过点击New snippet
按钮,添加一些代码片段,然后选中某一个代码片段文件,右键Run
去执行该代码片段:

代码编辑器窗格
可以在编辑器中打开文件,断点调试或者格式化等。下面演示一下各个功能。
- 代码格式化
打开Page面板下网站的一个JS文件,如果JS是展示在一行,可以点击下面的一对{}
进行格式化:

- 添加简单断点
在我们上边格式化之后的JS文件,选中某一行,单击该行的行号,即可添加断点:

- 添加条件断点
在前面介绍的Snippets代码片段中添加一个片段文件,内容如下:
1 | console.log("Script snippet #1 start"); |
这段代码比较简单,当i小于5的时候进入循环,停在断点处。下面开始条件断点的设置:
先单击要添加条件断点的那一行的行号,右键,选择Add conditional breakpoint

然后在这个条件输入框中,输入一个条件,比如这里我们是i = 10
:

设置好条件断点之后,断点会变成黄色,区别于普通断点:

为了便于观察i的值,可以在最右边的调试窗格变量监控一栏添加观察i的值。

最后右键运行该文件,如果条件断点正确的打上的话,变量监控值会看到i的值为10:

调试窗格
- XHR/fetch Breakpoints
XHR断点触发需要满足2个条件:一个是基于XHR的生命周期发生改变,一个是XHR的URL与我们设置的字符串相匹配。常用的是第二种。我们现在以百度作为一个演示。
打开百度网站首页,点击登录,然后打开Network面板,选择Fetch/XHR,我们进行一个抓包,只抓XHR请求的包,结果如下:

我们选择其中任意一个,比如下面一个请求,回到调试窗格,然后点击新增一个XHR断点,填入该请求的URL或者一部分:

然后我们退出登录后重新点击登录百度,可以看到设置的断点生效了:

- DOM Breakpoint
还是以百度为例,切换到元素面板,然后随便选择一个DOM元素,右键Break on:

有三种类型的断点,子元素改变/属性改变/节点删除。选择其中一个,即添加成功:

由于DOM Breakpoint在逆向中不是很常用,所以做一个了解即可。
- Event Listener Breakpoint
基于事件监听的断点。同样还是以百度为例,点击登录到登录页面,可以看到页面上是一个登录按钮的,这个登录按钮就是触发的submit事件。我们在调试窗格上找到Event Listener Breakpoints,然后打开Control,选中Submit:

然后我们点击登录页面的登录按钮,如无意外,断点成功打上:

- 断点控制按钮

第一个按钮:执行到下一个断点,如果没有下一个断点,则按照正常执行顺序执行到下一行代码。
第二个按钮:执行到下一行代码。
第三个按钮:点击进入下一个待执行的函数调用中去。
第四个按钮:跳出当前的函数调用。
第六个按钮:去除所有断点,恢复正常执行的方法。
- Call Stack
断点的调用栈列表。下面用一张图说一下调用栈顺序。

为了表述方便,把上边的几个方法分别重新命名,如上图。在栈顶的最后被调用,在栈底的最新被调用。调用顺序如下:
1 | function C() { |
至于XMLHttpRequest.send接下来会调用哪一个方法,我们无从得知。此外,注意到那个蓝色箭头,表示当前调试执行的代码所在的方法,如果我们点开了很多文件,想快速回到我们正在调试的那一行代码可以通过鼠标点击调用栈栈顶的方法即可返回到调用处。
- Scope
断点所在作用域内容。
Console面板
在逆向中,console这个交互环境,经常用来输出一些变量的值。有一个方法console.count
提一下,经常用来统计某一个方法的调用次数。用法比较简单,如下:

console面板还有一些骚操作,如下:
- console.table
我们可以在console中使用console.table,以表格形式展示数据。这里做一个示例:
打开console控制台,定义一个变量,内容如下:
1 | var data = [{"name": "zhangsan", "age": 21}, {"name": "lisi", "age": 22}] |
然后我们调用console.table
输出这个变量:

- copy
可以在console中调用copy方法,将某一个变量的值复制到剪切板,比如上边的data,我们调用copy(data)就可以将data的内容复制到剪切板了。
- $
$_ 表达的是上一次表达式计算的值。
$可以当作document.querySelect使用。
$$可以当作document.querySelectAll来使用。
$x可以当作xpath选择器来使用。

总结
本文介绍了浏览器开发者工具的使用技巧,主要介绍了三个面板:Console面板,Network面板和Source面板,是JS逆向必须掌握的知识。
