Ajax分析方法


这里还是以上篇文章 什么是Ajax?中的微博为例,我们知道拖动刷新的内容是由Ajax加载,而且页面的URL没有变化,那么应该去哪里查看这些Ajax请求呢?

1.查看请求

这里还需要借助浏览器的开发者工具,下面以Chrome浏览器为例来介绍。
首先,用Chrome浏览器打开微博链接https://m.weibo.cn/u/1251000504,随后页面中点击鼠标右键,从弹出的快捷菜单中选择“检查”选项(或者直接按F12),此时便会弹出开发者工具,如图所示
在这里插入图片描述
此时在Elements选项卡中便会观察到网页的源代码,右侧便是节点的样式。
不过这不是我们想搜寻的内容。切换到Network选项卡,随后重新刷新页面,可以发现这里出现了非常多的条目,如图:
在这里插入图片描述
前面也提到过,这里其实就是在页面加载过程中浏览器与服务器之间发送请求和接收响应的所有记录。
Ajax其实有特殊的请求类型,它叫做xhr。在下面图中,我们可以发现一个名称以getIndex开头的请求,其Type为xhr,这就是一个Ajax请求。用鼠标点击这个请求,可以查看这个请求的详细信息。
在这里插入图片描述
在右侧可以观察到其Request Headers、URL和Response Headers等信息。其中Request Headers中有一个信息为X-Requested-With:XMLHttpRequest,这就标记了此请求是Ajax请求,如图:
在这里插入图片描述
随后点击一下Preview,即可看到响应的内容,它是JSON格式的。这里Chrome为我们自动做了解析,点击箭头即可展开和收起相应内容,如图:
在这里插入图片描述
观察可以发现,这里的返回结果是个人信息,如昵称、简介、头像等,这也是用来渲染个人主页所使用的数据。JavaScript接收到这些数据之后,再执行相应的渲染方法,整个页面就渲染出来了。
另外,也可以切换到Response选项卡,从中观察到真实的返回数据,如图:
在这里插入图片描述
接下来,切回到第一个请求,观察一下它的Response是什么,如图
在这里插入图片描述
这是最原始的链接https://m.weibo.cn/u/1251000504返回的结果,其代码只有不到50行,结构也非常简单,只是执行了一些JavaScript
所以说,我们看到的微博页面的真实数据并不是最原始的页面返回的,而是后来执行JavaScript后再次向后台发送了Ajax请求,浏览器拿到数据后再进一步渲染出来的。

2.过滤请求

接下来,再利用Chrome开发者工具的筛选功能筛选出所有的Ajax请求。在请求上方有一层筛选栏,直接点击XHR,此时在下方显示的所有请求便都是Ajax请求了,如图:
在这里插入图片描述
接下来,不断滑动页面,可以看到页面底部有一条条新的微博被刷出,而开发者工具下方也一个个地出现Ajax请求,这样我们就可以捕获到所有Ajax请求了。
随意点开一个条目,都可以清楚的看到其Request URL、Request Hearders、Response Headers、ResponseBody等内容,此时想要模拟请求和提取就非常简单了。
如图所示的内容便是某一页微博的列表信息。
在这里插入图片描述
到现在为止,我们已经可以分析出Ajax请求的一些详细信息了,接下来只需要用程序模拟这些Ajax请求,就可以轻松提取我们所需的信息了。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

降温vae+

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值