一、Http协议
- 什么是协议
双方在交互、通讯的时候, 遵守的一种规范、规则。
-
1.http概述
- 规定了客户端和服务器端之间进行通信的协议。
- 基于TCP/IP协议的应用层协议,一次请求一次响应后,主动断开连接
- 物理层/数据链路层/网络层/传输层/会话层/表示层/应用层
-
2.基本原则
- 基于请求响应模型
- 一次请求对应一次响应
- 请求只能由客户端发出, 服务器端只能被动的等待请求做出响应。
-
版本
- 1.0
请求数据,服务器返回后, 将会断开连接
- 1.1
请求数据,服务器返回后, 连接还会保持着。 除非服务器 | 客户端 关掉。 有一定的时间限制,如果都空着这个连接,那么后面会自己断掉。
二、演示客户端 如何 与服务器端通讯。
在地址栏中键入网络地址 回车 或者是平常注册的时候,点击了注册按钮 , 浏览器都能显示出来一些东西。那么背地里到底浏览器和服务器是怎么通讯。 它们都传输了哪些数据。
-
安装抓包工具 HttpWatch (IE插件)
-
打开tomcat. 输入localhost:8080 打开首页
-
在首页上找到Example 字样
6.x 和 7.x 的文档页面有所不同,但是只要找到example就能够找到例子工程
- 选择 servlet 例子 —> Request Parameter
接着点击Request Parameters 的 Execute超链接
执行tomcat的例子,然后查看浏览器和 tomcat服务器的对接细节
三、Http请求数据解释
请求的数据里面包含三个部分内容 : 请求行 、 请求头 、请求体
- 请求行
POST /examples/servlets/servlet/RequestParamExample HTTP/1.1
POST :请求方式,以post去提交数据
/examples/servlets/servlet/RequestParamExample
请求资源的地址路径 , 就是要访问哪个地方。
HTTP/1.1 协议版本
- 若干请求头
Accept: application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, */*
Referer: http://localhost:8080/examples/servlets/servlet/RequestParamExample
Accept-Language: zh-CN
User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E)
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip, deflate
Host: localhost:8080
Content-Length: 31
Connection: Keep-Alive
Cache-Control: no-cache
Accept: 客户端向服务器端表示,我能支持什么类型的数据。
Referer : 真正请求的地址路径,全路径
Accept-Charset: ISO-8859-1:通知服务器当前浏览器可以接受的字符集编码
Accept-Language: 浏览器可以接受的语言环境, 和国际化相关的头
User-Agent: 用户代理 向服务器表明,当前来访的客户端信息。
Content-Type: 提交的数据类型。经过urlencoding编码的form表单的数据
Accept-Encoding:gzip,deflate:压缩算法,浏览器可以接受的压缩格式 。
Host : 访问的虚拟主机的名称或主机地址
Content-Length: 数据长度
Connection : Keep-Alive 保持连接
Cache-Control :对缓存的操作
- 请求体
浏览器真正发送给服务器的数据
发送的数据呈现的是key=value ,如果存在多个数据,那么使用 &
firstname=zhang&lastname=sansan
四、Http响应数据解析
请求的数据里面包含三个部分内容 : 响应行 、 响应头 、响应体
响应头
HTTP/1.1 200 OK
HTTP/1.1: 当前所遵循的协议版本
200: 响应码,一个3位的数字, 范围为100~600, 表示服务器处理请求的结果
200~299 表示服务器正确的处理了请求
300~399 表示服务器正确的处理了本次请求,但是如果想要继续执行,还需要更多的额外信息
400~499 表示客户端的请求有问题
500~599 表示服务器端发生了问题
200 表示服务器处理成功
302 表示请求重定向
304/307 通知浏览器使用缓存资源
404 表示客户端请求的资源不存在
500 表示服务器端处理请求出错
OK: 描述字符
Server: Apache-Coyote/1.1 服务器的基本信息
Content-Type: text/html;charset=ISO-8859-服务器发送的数据的格式
Content-Length: 673 服务器发送的数据的大小
Date: Fri, 17 Feb 2017 02:53:02 当前收到响应的时间
Connection: close/Keep-Alive -- 是否保持连接
Pragma: no-cache -- 通知浏览器是否缓存
Expires: -1 -- 通知浏览器是否缓存
Content-Encoding: gzip -- 服务器发送的数据使用的压缩格式
Set-Cookie:SS=Q0=5Lb_nQ; path=/search -- 和Cookie相关的头
Content-Language: zh-cn --服务器发送的数据使用的语言环境 国际化相关的头
Refresh: 1;url=http:定时刷新相关的头,通知浏览器,过几秒后自动刷新访问哪个地址
...这里还有很多数据...
响应行
HTTP/1.1 200 OK
协议版本
状态码
咱们这次交互到底是什么样结果的一个code.
200 : 成功,正常处理,得到数据。
403 : for bidden 拒绝
404 : Not Found
500 : 服务器异常
OK
对应前面的状态码
- 响应体
实体内容
xxxxxx
五、Get 和 Post请求区别
-
post
1. 数据是以流的方式写过去,不会在地址栏上面显示。 现在一般提交数据到服务器使用的都是POST 2. 以流的方式写数据,所以数据没有大小限制。
-
get
1. 会在地址栏后面拼接数据,所以有安全隐患。 一般从服务器获取数据,并且客户端也不用提交上面数据的时候,可以使用GET 2. 能够带的数据有限, 1kb大小
六、Web资源
在http协议当中,规定了请求和响应双方, 客户端和服务器端。与web相关的资源。
有两种分类
-
静态资源
html 、 js、 css
-
动态资源
servlet/jsp