实验1 Wireshark协议分析HTTP协议.docx

上传人:b****1 文档编号:13838731 上传时间:2023-06-17 格式:DOCX 页数:12 大小:587.16KB
下载 相关 举报
实验1 Wireshark协议分析HTTP协议.docx_第1页
第1页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第2页
第2页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第3页
第3页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第4页
第4页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第5页
第5页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第6页
第6页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第7页
第7页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第8页
第8页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第9页
第9页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第10页
第10页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第11页
第11页 / 共12页
实验1 Wireshark协议分析HTTP协议.docx_第12页
第12页 / 共12页
亲,该文档总共12页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

实验1 Wireshark协议分析HTTP协议.docx

《实验1 Wireshark协议分析HTTP协议.docx》由会员分享,可在线阅读,更多相关《实验1 Wireshark协议分析HTTP协议.docx(12页珍藏版)》请在冰点文库上搜索。

实验1 Wireshark协议分析HTTP协议.docx

实验1Wireshark协议分析HTTP协议

实验二利用Wireshark分析协议HTTP

一、实验目的

分析HTTP协议

二、实验环境

与因特网连接的计算机,操作系统为Windows,安装有Wireshark、IE等软件。

三、实验步骤

1、利用Wireshark俘获HTTP分组

(1)在进行跟踪之前,我们首先清空Web浏览器的高速缓存来确保Web网页是从网络中获取的,而不是从高速缓冲中取得的。

打开浏览器,找到Internet选项,点击后出现如图1所示的界面。

以IE浏览器为例,步骤为:

点击浏览器右上角的“工具”-“Internet选项”。

图1Internet选项

之后,还要在客户端清空DNS高速缓存,以确保Web服务器域名到IP地址的映射是从网络中请求的。

在Windows系列的机器上,可在命令提示行输入ipconfig/flushdns完成操作(如图2所示);具体步骤及Linux、MAC等系统的清空方法请参见:

图2命令提示行输入ipconfig/flushdns完成操作

(2)启动Wireshark分组俘获器。

(3)在Web浏览器中输入:

(重庆大学网站)。

(4)停止分组俘获。

图3利用Wireshark俘获的HTTP分组

在URL中,是一个具体的web服务器的主机名。

最前面有两个DNS分组。

第一个分组是将主机名转换成为对应的IP地址的请求,第二个分组包含了转换的结果。

这个转换是必要的,因为网络层协议——IP协议,是通过点分十进制来表示因特网主机的,而不是通过这样的主机名。

当输入URL时,将要求Web服务器从主机上请求数据,但首先Web浏览器必须确定这个主机的IP地址。

小提示--域名和主机关系举例:

域名下,有主机server1和server2,其主机全名就是和。

随着转换的完成,Web浏览器与Web服务器建立一个TCP连接。

最后,Web浏览器使用已建立好的TCP连接来发送请求“GET/HTTP/”。

这个分组描述了要求的行为(“GET”)及文件(只写“/”是因为我们没有指定额外的文件名),还有所用到的协议的版本(“HTTP/”)。

2、HTTPGET/response交互

(1)在协议框中,选择“GET/HTTP/”所在的分组会看到这个基本请求行后跟随着一系列额外的请求首部。

在首部后的“\r\n”表示一个回车和换行,以此将该首部与下一个首部隔开。

“Host”首部在版本中是必须的,它描述了URL中机器的主机,本例中是。

这就允许了一个Web服务器在同一时间支持许多不同的主机名。

User-Agent首部描述了提出请求的Web浏览器及客户机器(有彩蛋哟,自己找)。

接下来是一系列的Accept首部,包括Accept(接受)、Accept-Language(接受语言)、Accept-Encoding(接受编码)、Accept-Charset(接受字符集)。

它们告诉Web服务器客户Web浏览器准备处理的数据类型。

Web服务器可以将数据转变为不同的语言和格式。

Keep-Alive及Connection首部描述了有关TCP连接的信息,通过此连接发送HTTP请求和响应。

它表明在发送请求之后连接是否保持活动状态及保持多久。

大多数连接是持久的(persistent),意思是在每次请求后不关闭TCP连接,而是保持该连接以接受从同一台服务器发来的多个请求。

(2)我们已经分析了由Web浏览器发送的请求,现在我们来观察Web服务器的回答。

响应首先发送“HTTP/200ok”,指明它开始使用版本来发送网页。

同样,在响应分组中,它后面也跟随着一些首部。

最后,被请求的实际数据被发送。

第一个Cache-control首部,用于描述是否将数据的副本存储或高速缓存起来,以便将来引用。

一般个人的Web浏览器会高速缓存一些本机最近访问过的网页,随后对同一页面再次进行访问时,如果该网页仍存储于高速缓存中,则不再向服务器请求数据。

类似地,在同一个网络中的计算机可以共享一些存在高速缓存中的页面,防止多个用户通过到其他网路的低速网路连接从网上获取相同的数据。

这样的高速缓存被称为代理高速缓存(proxycache)。

在我们所俘获的分组中我们看到“Cache-control”首部值是“private”的。

这表明服务器已经对这个用户产生了一个个性化的响应,而且可以被存储在本地的高速缓存中,但不是共享的高速缓存代理。

在HTTP请求中,Web服务器列出内容类型及可接受的内容编码。

此例中Web服务器选择发送内容的类型是text/html且内容编码是gzip。

这表明数据部分是压缩了的HTML。

服务器描述了一些关于自身的信息。

此例中响应分组还用Content-Length首部描述了数据的长度。

最后,服务器还在Date首部中列出了数据发送的日期和时间。

根据俘获窗口内容,回答“四、实验报告内容”中的1-6题。

3、HTTP条件GET/response交互

(1)启动浏览器,清空浏览器的缓存。

(2)启动Wireshark分组俘获器,开始Wireshark分组俘获。

(3)在浏览器地址栏中如下网址:

你的浏览器中将显示一个的非常简单的HTML文件。

(4)在你的浏览器中重新输入相同的URL或单击浏览器中的“刷新”按钮。

(5)停止Wireshark分组俘获,在显示过滤筛选说明处输入“http”,分组列表子窗口中将只显示所俘获到的HTTP报文。

根据操作回答“四、实验报告内容”中的7-10题。

如果抓到的包太多,不好分析,可以在过滤处输入contains"wireshark",“wireshark”可以换成想查的网址中的词,就可以把想要的内容过滤出来。

Wireshark过滤语法总结附后。

4、获取长文件

(1)启动浏览器,将浏览器的缓存清空。

(2)启动Wireshark分组俘获器,开始Wireshark分组俘获。

(3)在浏览器地址栏中输入如下网址:

(注:

此抓包网址和第3部分不一样)

浏览器将显示一个相当大的美国权力法案。

(4)停止Wireshark分组俘获,在显示过滤筛选说明处输入“http”,分组列表子窗口中将只显示所俘获到的HTTP报文。

根据操作回答“四、实验报告内容”中的11-14题。

5、嵌有对象的HTML文档

(1)启动浏览器,将浏览器的缓存清空。

(2)启动Wireshark分组俘获器。

开始Wireshark分组俘获。

(3)在浏览器地址栏中输入如下网址:

(注:

此抓包网址和第4部分不一样)

浏览器将显示一个具有两个图片的短HTTP文件。

(4)停止Wireshark分组俘获,在显示过滤筛选说明处输入“http”,分组列表子窗口中将只显示所俘获到的HTTP报文。

根据操作回答“四、实验报告内容”中的15-16题。

6、HTTP认证

(1)启动浏览器,将浏览器的缓存清空。

(2)启动Wireshark分组俘获器。

开始Wireshark分组俘获。

(3)在浏览器地址栏中输入如下网址:

浏览器将显示一个HTTP文件,输入所需要的用户名和密码(用户名:

wireshark-students,密码:

network)。

(4)停止Wireshark分组俘获,在显示过滤筛选说明处输入“http”,分组列表子窗口中将只显示所俘获到的HTTP报文。

根据操作回答“四、实验报告内容”中的17-18题。

四、实验报告内容

在实验的基础上,回答以下问题:

(1)你的浏览器运行的是,还是你所访问的服务器所运行的HTTP版本号是多少

参考答案:

浏览器运行的是

访问的服务器运行的是

(2)你的浏览器向服务器指出它能接收何种语言版本的对象

参考答案:

接收简体中文

(3)你的计算机的IP地址是多少服务器的IP地址是多少

参考答案:

我的计算机IP:

服务器没有明确返回文件内容。

因为返回304状态码,意思是不返回文件内容。

具体原因:

浏览器端缓存页面最后修改时间与服务器端时间一致,返回304状态码,客户端接到之后,就直接把本地缓存文件显示到浏览器中。

(4)你的浏览器一共发出了多少个HTTPGET请求

参考答案:

一个

(5)承载这一个HTTP响应报文一共需要多少个data-containingTCP报文段

需要四个data-containingTCP报文段。

(6)与这个HTTPGET请求相对应的响应报文的状态代码和状态短语是什么

参考答案:

200OK

(7)在被传送的数据中一共有多少个HTTP状态行与TCP-induced“continuation”有关

参考答案:

一个,注意,虽然有四个data-containingTCP报文段,但只有这一个状态行与他们相关。

(8)你的浏览器一共发出了多少个和打开的网址相关的HTTPGET请求这些请求被发送到的目的地的IP地址是多少

参考答案:

五个HTTPGET请求。

目的地址分别是、、

、、(可能不同版本、不同情况下抓出来的不一样,根据实际情况分析)

(9)浏览器在下载这两个图片时,是串行下载还是并行下载请解释。

参考答案:

并行,因为两个图片是连续请求,不需要等第一个请求得到回复后才继续第二次请求。

有时候不同网络环境下,可能抓到的包是在对应请求得到回应后才继续第二次的请求,有时候是不需要等第一个请求得到回复后才继续第二次请求。

可以多抓几次试试。

只有存在不需要等第一个请求得到回复后才继续第二次请求的情况,就说明是并行的。

(10)对于浏览器发出的最初的HTTPGET请求,服务器的响应是什么(状态代码和状态短语)

参考答案:

401Unauthorized

(18)当浏览器发出第二个HTTPGET请求时,在HTTPGET报文中包含了哪些新的字段

参考答案:

 

参考资料:

1.协议

协议

和的比较

2.http状态码大全

3.Last-Modified与If-Modified-Since都是用来记录页面的最后修改时间。

当客户端访问页面时,服务器会将页面最后修改时间通过Last-Modified标识由服务器发往客户端,客户端记录修改时间,再次请求本地存在的cache页面时,客户端会通过If-Modified-Since头将先前服务器端发过来的最后修改时间戳发送回去,服务器端通过这个时间戳判断客户端的页面是否是最新的,如果不是最新的,则返回新的内容,如果是最新的,则返回304告诉客户端其本地cache的页面是最新的,于是客户端就可以直接从本地加载页面了,这样在网络上传输的数据就会大大减少,同时也减轻了服务器的负担。

4.协议详解

5.、Linux、MAC系统更新DNS缓存的方法

6.过滤语法

有两种过滤器:

捕捉过滤器(CaptureFilters):

用于决定将什么样的信息记录在捕捉结果中。

显示过滤器(DisplayFilters):

用于在捕捉结果中进行详细查找。

捕捉过滤器在抓包前进行设置,决定抓取怎样的数据;显示过滤器用于过滤抓包数据,方便stream的追踪和排查。

捕捉过滤器仅支持协议过滤,显示过滤器既支持协议过滤也支持内容过滤。

两种过滤器它们支持的过滤语法并不一样。

常用的过滤语法如下:

contains"wireshark"

==!

=or!

===显示来自网段的封包。

==25显示来源或目的TCP端口号为25的封包。

==25显示目的TCP端口号为25的封包。

"POST"显示post请求方式的http封包。

==""显示请求的域名为的http封包。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 自然科学 > 物理

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2