一、HTTP的基本介绍
1.概念
是超文本传输协议,规定了浏览器和服务器之间数据传输的规则,一个是请求数据的格式,一个是响应数据的格式。
2.特点
基于TCP协议:面向连接,安全。
基于请求-响应模型的:一次请求对应一次响应。
HTTP协议是无状态的协议:对于事物处理没有记忆能力。每次请求-响应都是独立的。
缺点:多次请求间不能共享数据。
有点:速度快。
例子:一个管理系统,需要登录后才能适用系统中的功能。但是HTTP协议没有记忆能力,所以登录(请求1)之后,点击某个功能(请求2)时无法判断现在是否是登录状态。
二、请求协议(即HTTP请求数据的格式)
分为三个部分:请求行、请求头、请求体
1.请求行
请求行就是请求数据的第一行,由请求方式、资源路径、协议这三个部分组成
GET:请求参数在请求行中、没有请求体,但是请求大小是有限制的。
POST :请求参数在请求体中,POST请求大小是没有限制的。
2.请求头
Host:请求的主机名。
User-Agent:浏览器版本。
Accept:表示浏览器能接受的资源类型,如text/*、image/*、或者*/*表示所有。
Accept-Language:表示浏览器偏好的语言,服务器可以据此返回不同语言的网页。
Accept-Encoding:表示浏览器可以支持的压缩类型,例如gzip,deflate等。
Content-Type:请求主体的数据类型。
Content-Length:请求主体的大小(单位:字节)。
3.请求体
POST请求有请求体GET请求没有,请求体存放请求参数。
三、响应协议(即HTTP响应数据的格式)
分为三个部分:响应行、响应头、响应体。
1.响应行
响应行就是响应数据的第一行,由协议、状态码、描述这三个部分组成。
如HTTP/1.1 200 OK,HTTP/1.11就是协议以及协议的版本;200就是响应的状态码;OK就是用来描述前面的状态的,OK就是成功响应的意思。
响应状态码:
1xx | 响应中-临时状态码,表示请求已经接收,告诉客户端应该继续请求或者如果它已经完成则忽略它。 |
2xx | 成功-表示请求已经被成功接收,处理已完成。 |
3xx | 重定向-重定向到其他地方;让客户端再发起一次请求以完成整个处理。 |
4xx | 客户端错误-处理发生错误,责任在客户端。如:请求了不存在的资源、客户端未被授权、禁止访问等。 |
5xx | 服务器错误-处理发生错误,责任在服务端。如:程序抛出异常等。 |
具体的响应状态码:
状态码 | 英文描述 | 解释 |
---|---|---|
200 | OK | 客户端请求成功,即处理成功,这是我们最想看到的状态码 |
302 | Found | 指示所请求的资源已移动到由Location响应头给定的URL,浏览器会自动重新访问到这个页面 |
304 | Not Modified | 告诉客户端,你请求的资源至上次取得后,服务端并未更改,你直接用你本地缓存吧。隐式重定向 |
400 | Bad Request | 客户端请求有语法错误,不能被服务器所理解 |
403 | Forbidden | 服务器收到请求,但是拒绝提供服务,比如:没有权限访问相关资源 |
404 | Not Found | 请求资源不存在,一般是URL输入有误,或者网站资源被删除了 |
405 | Method Not Allowed | 请求方式有误,比如应该用GET请求方式的资源,用了POST |
428 | Precondition Required | 服务器要求有条件的请求,告诉客户端要想访问该资源,必须携带特定的请求头 |
429 | Too Many Requests | 指示用户在给定时间内发送了太多请求(“限速"),配合 Retry-Afer(多长时间后可以请求)响应头一起使用 |
431 | Request Header Fields Too Large | 请求头太大,服务器不愿意处理请求,因为它的头部字段太大。请求可以在减少请求头域的大小后重新提 交。 |
500 | Internal server Error | 服务器发生不可预期的错误。服务器出异常了,赶紧看日志去吧 |
503 | Service unavailable | 服务器尚未准备好处理请求,服务器刚刚启动,还未初始化好 |
2.响应头
第二行开始,格式key:value。
Content-Type | 表示该响应内容的类型,例如text/html,application/json。 |
Content-Length | 表示该响应内容的长度(字节数)。 |
Content-Encoding | 表示该响应压缩算法,例如gzip。 |
Cache-Control | 指示客户端应如何缓存,例如max-age=300表示可以最多缓存300秒。 |
Set-Cookie | 告诉浏览器为当前页面所在的域设置cookie。 |
3.响应体
最后一部分,存放响应数据,一般也叫响应正文,配合着前端的代码实现就可以展示对应的页面信息。
四、HTTP协议的解析
客户端浏览器内置了解析HTTP的程序,服务器端需要通过代码对请求数据进行解析,然后参照HTTP的响应数据格式给浏览器响应对应的数据(这块可以用Web服务器,比如WebLogic、WebSphere、Apache Tomcat)。