HTTP

58 阅读5分钟

一、HTTP简介

HTTP ( HyperText Transfer Protocol ) 超文本传输协议

规定了浏览器和服务器之间数据传输的规则。

- 数据传输的规则指的是请求数据和响应数据需要按照指定的格式进行传输。
- 如果想知道具体的格式,可以打开浏览器,点击`F12`打开开发者工具,
  点击`Network`来查看某一次请求的请求数据和响应数据具体的格式内容

二、HTTP特点

1.基于TCP协议: 面向连接,安全 
2.基于请求-响应模型:一次请求对应一次响应
3.HTTP协议是无状态协议:对于事物处理没有记忆能力。每次请求-响应都是独立的
    -   缺点:多次请求间不能共享数据
    -   优点:速度快
    
    使用会话技术(Cookie、Session)来解决多次请求之间不能共享数据问题

三、请求数据格式

请求数据总共分为三部分内容:请求行,请求头,请求体。

image.png

1.请求行

请求行: HTTP请求中的第一行数据,请求行包含三块内容,分别是 GET[请求方式] /[请求URL路径] HTTP/1.1[HTTP协议及版本]

请求方式有七种,最常用的是GET和POST

2.请求头

请求头: 第二行开始,格式为key: value形式
常见的HTTP请求头有:
    Host: 表示请求的主机名
    User-Agent: 浏览器版本,例如Chrome浏览器的标识类似Mozilla/5.0 ...Chrome/79,IE浏览器的标识类似Mozilla/5.0 (Windows NT ...)like Gecko;
    Accept:表示浏览器能接收的资源类型,如text/*,image/*或者*/*表示所有;
    Accept-Language:表示浏览器偏好的语言,服务器可以据此返回不同语言的网页;
    Accept-Encoding:表示浏览器可以支持的压缩类型,例如gzip, deflate等。
    
请求头的作用:

    服务器可以通过request对象获取请求头的数据,由于不同浏览器对代码响应结果不同,
    所以可以根据请求头数据获取客户端浏览器类型,来设置不同的代码,达到一致的效果(浏览器兼容问题)

3.请求体

image.png

请求体: POST请求的最后一部分,存储请求参数
如上图红线框的内容就是请求体的内容,请求体和请求头之间是有一个空行隔开。是一个POST请求。

-   GET请求请求参数在请求行中,没有请求体,POST请求请求参数在请求体中
-   GET请求请求参数大小有限制,POST没有

所以有请求体的请求都是POST请求。

四、响应数据格式

响应数据总共分为三部分内容:响应行,响应头,响应体。

image.png

1.响应行

-   响应行:响应数据的第一行,响应行包含三块内容,分别是 HTTP/1.1[HTTP协议及版本] 200[响应状态码] ok[状态码的描述]

2.响应头

-   响应头:第二行开始,格式为key:value形式
    
    响应头中会包含若干个属性,常见的HTTP响应头有:
    
        Content-Type:表示该响应内容的类型,例如text/html,image/jpeg;
        Content-Length:表示该响应内容的长度(字节数);
        Content-Encoding:表示该响应压缩算法,例如gzip;
        Cache-Control:指示客户端应如何缓存,例如max-age=300表示可以最多缓存300

3.响应体

响应体: 最后一部分。存放响应数据

上图中<html>...</html>这部分内容就是响应体,它和响应头之间有一个空行隔开

4.响应状态码

状态码分类说明
1xx响应中——临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它
2xx成功——表示请求已经被成功接收,处理已完成
3xx重定向——重定向到其它地方:它让客户端再发起一个请求以完成整个处理。
4xx客户端错误——处理发生错误,责任在客户端,如:客户端的请求一个不存在的资源,客户端未被授权,禁止访问等
5xx服务器端错误——处理发生错误,责任在服务端,如:服务端抛出异常,路由出错,HTTP版本不支持等
状态码英文描述解释
200OK客户端请求成功,即处理成功,这是我们最想看到的状态码
302Found指示所请求的资源已移动到由Location响应头给定的 URL,浏览器会自动重新访问到这个页面
304Not Modified告诉客户端,你请求的资源至上次取得后,服务端并未更改,你直接用你本地缓存吧。隐式重定向
400Bad Request客户端请求有语法错误,不能被服务器所理解
403Forbidden服务器收到请求,但是拒绝提供服务,比如:没有权限访问相关资源
404Not Found请求资源不存在,一般是URL输入有误,或者网站资源被删除了
428Precondition Required服务器要求有条件的请求,告诉客户端要想访问该资源,必须携带特定的请求头
429Too Many Requests太多请求,可以限制客户端请求某个资源的数量,配合 Retry-After(多长时间后可以请求)响应头一起使用
431Request Header Fields Too Large请求头太大,服务器不愿意处理请求,因为它的头部字段太大。请求可以在减少请求头域的大小后重新提交。
405Method Not Allowed请求方式有误,比如应该用GET请求方式的资源,用了POST
500Internal Server Error服务器发生不可预期的错误。服务器出异常了,赶紧看日志去吧
503Service Unavailable服务器尚未准备好处理请求,服务器刚刚启动,还未初始化好
511Network Authentication Required客户端需要进行身份验证才能获得网络访问权限