内容
回顾之前的内容,在windows系统上实际操作,用几个应用软件搭建出一个“最小化”的HTTP实验环境,方便后续的“基础篇”“进阶篇”“安全篇”。
前期回顾
HTTP协议诞生于30年前,设计之初的目的是用来传输从文本数据,但由于形势灵活,搭配URI、HTML等技术能够把互联网上的资源都联系起来,构成一个复杂的超文本系统,让人们能自由的获取信息,所以得到了迅猛的发展。
HTTP有多个版本,目前应用最广泛的是HTTP 1.1.他几乎可以说是整个互联网的基石,但是他的性能难以满足如今的高流量网站,于是又出现了HTTP2、 HTTP3,不过这两个新版本的协议还没有完全推广开,所以在可见的将来HTTP1.1还会继续存在下去。
HTTP翻译成中文,它是超文本传输协议,是一个应用层的协议,通常基于TCP IP,能够在网络的任意两点之间传出文字,图片,音频,视频等数据。HTTP协议中的两个端点,为请求方与应答方,请求方通常是web浏览器,也叫user agent,应答方上web服务器,存储着网络上的大部分静态或动态的资源。
在服务器和浏览器之间还有一些中间人的角色,比如cdn网关代理等,他们也同样遵守HTTP协议,可以帮助用户快速安全的获取资源。HTTP协议,它不是一个孤立的协议,需要下层很多其他协议的配合,最基本的是TCP IP,实现寻址路由和可靠的数据传输,还有DNS协议实现对互联网上主机的定位查找。所以基于此对HTTP更准确的称呼是HTTP over TCP/IP。而另外一个HTTP over SSL/TLS,就是增加了安全功能的HTTPS。
软件介绍
开始搭建一个最小化的环境,在这个环境里仅有HTTP协议的两个端点,请求方和应答方,去除一切多余的环节,从而可以抓住重点,掌握HTTP的本质。
可能会运用到的软件:
- WireShark
- Chrome/Firefox
- Telnet
- OpenResty
Wireshark:是著名的网络抓包工具,能够截获在TCP IP协议战中传输的所有流量,并按协议、类型、地址端口等任意过滤,功能非常强大,是学习网络协议的必备工具。
我们来打个比方,他就像是网络世界里的一台高速摄像机,他只在一瞬间发生的网络传输过程中,如实地拍摄下来所有的慢速回报,让我们能够静下心来分析,那一瞬间到底发生了什么事情。
Chrome:是是谷歌开发的浏览器,是目前主就目前的主流浏览器之一,它不仅上网方面也是很好的调试器,对HTTP1.1、HTTPs、HTTP2,QUIC等协议都支持的特别好,用f12打开开发者工具,可以非常详细的工作到HTTP传输过程中的各种数据。
但是,和WireShark相比,浏览器更像是事后诸葛亮,不能观测到HTTP传输的全过程,只能观测到结果。
Telnet:是一个经典的虚拟终端,基于TCP协议远程登录主机,我们可以使用它来模拟浏览器的行为,连接服务器后主动发送HTTP请求,把浏览器的干扰也彻底清除,能够从最原始的层面上去研究HTTP协议。
OpenResty:是基于Nginx的一个强化包,里面除了Nginx还有一大堆有用的功能模块,不仅支持HTTP/HTTPs,还能特别集成脚本语言Lua,简化Nginx二次开发,方便快速地搭建动态网关,更能够当成应用容器来编写业务逻辑。
选择OpenResty而不直接用Nginx的原因是他相当于Nginx的超集,功能更丰富,安装部署更方便。之后也会用Lua编写一些服务端脚本,实现简单的web服务器相应逻辑,方便实验。
安装过程
-
Telnet
win10自带Telnet,不需要安装,但默认是不启用的,需要稍微设置一下。打开windows的设置窗口,搜索telnet,就会找到启用或关闭windows功能,在这个窗口里找到Telnet客户端,打上对勾就可以了。
-
OpenResty
把OpenResty的压缩包解压到文件夹中,改名为openresty
测试验证
-
启动web服务器,OpenResty,在文件夹里,有四个批处理文件:
1)start:启动OpenResty服务器
2)stop:停止OpenResty服务器
3)reload:重启OpenResty服务器
4)list:列出已经启动的OpenResty服务器
先打开Start批处理文件,就会启动OpenResty服务器。然后打开List,查看是否已经政策启动。
- 打开WireShark,开始抓包
因为我们的实验环境是本机的127.0.0.1上,也就是Loopback 环回地址,所以在wireshark里要选择“NPcap Loopback Adapter”,过滤器选择 TCP port Http,只抓取HTTP相关的数据包,然后双击NPcap Loopback Adapter,就可以开始抓取本机上的网络数据了。
然后,打开chrome,输入 http://localhost/,访问刚才启动的OpenResty服务器,就会看到一个简单的欢迎界面。
再回头看WireShark,应该就会显示已经抓到的数据了。
至于这些数据内容是什么,会在之后慢慢做介绍。之后,记得停止OpenResty服务器。
小结
- 现实的网络环境太复杂,有很多干扰因素,搭建最小化的环境可以快速抓住重点,掌握HTTP的本质。
- 选择wireShark作为抓包工具,捕获在TCP/IP协议栈中传输的所有流量
- 选择Chrome浏览器,作为HTTP协议中的user agent
- 选择OpenResty 作为web服务器,他是一个Nginx的强化包,功能非常丰富
- Telnet是一个命令行工具,可以用来登录主机模拟浏览器操作