HTTP协议知识点速览

更新日期: 2019-11-20阅读: 2.2k标签: http

什么是HTTP?

HTTP(HyperText Transfer Protocol),中文「超文本传输协议」。

  • 是互联网应用最广泛的网络协议
  • 基于 TCP 的应用层协议
  • 浏览器与服务器之间的数据传输协议。
  • HTTP 协议和其他应用层协议一样,本质上是一种通信格式。
  • HTTP 是信封,信封里面的信(html)是内容;但是没有信封,信也没办法寄出去。

HTTP的特点

  • 无连接:每次连接只处理一个请求,可以节省传输时间。
  • 无状态:服务器不知道你是谁。

HTTP工作原理

HTTP 协议工作在客户端-服务端架构上,即浏览器作为客户端通过 URL 向 Web 服务器发送所有请求,Web服务器接收请求后,向浏览器发送响应信息。


HTTP报文

请求报文

组成部分描述
请求行包含请求方法、URI、HTTP版本。
请求头告诉服务器关于客户端请求的信息。
空行告诉浏览器下一个是请求体。
请求体一条 HTTP 消息要传输的主体。

响应报文

组成部分描述
状态行包含HTTP版本、状态码、状态信息
响应头类似请求头
空行告诉浏览器下一个是响应体
响应体类似请求体
  • 请求行和请求头(状态行和响应头)都是结构化的文本。
  • 主体可以包含任意的二进制数据(图片、视频、音频、软件程序等)。

Cookie和Session

HTTP 协议是无状态的,请求与请求之间没有联系。

服务器为了知道请求来自哪个客户,因此 Cookie 技术出现了。

Cookie

Cookie 包含在 HTTP 的请求头里,读取这个 Cookie 就知道用户是谁了。

本质上,Cookie 是一份存储在用户本地的文件,里面包含了每次请求需要传递的信息。

在 Chrome 中,通过下面的操作,可以查看浏览器储存的 Cookie。

设置 > 高级 > 隐私设置与安全性 > 网站设置 > Cookie和网站数据 > 查看所有 Cookie 和网站数据


Session

Cookie 以明文储存在本地,不够安全,需要 Seesion 来解决这个问题。

Session 是存在服务器的,里面包含了用户状态。

而 Cookie 中储存了 Session ID,当浏览器再次请求时,会把这个 Session ID 带上,服务器通过 Session ID 找到对应的 Session。

HTTP请求方法

请求方法描述
GET获取数据
POST传输数据
HEAD类似于 GET 请求,用于获取报文首部(请求头)。
PUT更新数据
DELETE删除数据

GET和POST的区别

  • GET 参数通过 URL 传递,POST 放在请求体中。
  • GET 参数长度有限制,POST 没有。
  • GET 比 POST 请求更安全,因为参数直接暴露给用户。
  • 浏览器回退时,GET 是无害的,POST会再次提交请求。
  • 浏览器会主动缓存 GET 请求,POST 不会,除非手动设置。

HTTP 状态码

HTTP 状态码根据第一个数字不同,可以分为 5 钟类型:

分类描述
1**指示信息-收到请求,继续处理
2**成功-请求被成功接收
3**重定向-需要进一步的操作,以完成请求
4**客户端错误-请求包含语法错误或无法完成请求
5**服务器错误-服务器在处理请求的过程中发生了错误

常见 HTTP 状态码

  • 200(OK):请求成功。
  • 206(Partial Content):客户端发送了一个Range的get请求,服务器完成了它。
  • 301 (Moved Permanently):永久重定向至新的 url。
  • 302(Found):临时重定向至新的url。
  • 304(Not Modified):服务器告诉浏览器缓存可以继续使用。
  • 400(Bad Request):客户端请求有语法错误,服务器理解不了。
  • 403(Forbidden):请求页面禁止访问。
  • 404 (Not Found):请求资源不存在。
  • 500 (Internal Server Error):服务器内部错误,无法完成请求。

HTTP历史

版本发布时间简介
HTTP/0.91991年该版本极其简单,只有一个命令GET,目前已不再使用。
HTTP/1.01996 年 5 月引入了多种功能,至今仍在使用当中。
HTTP/1.11997 年 1 月引入持久连接,是目前最流行的版本。
HTTP/22015 年 5 月引入了服务器推送等多种功能,是目前最新的版本。

持久连接

即 Keep-Alive 模式,保持 TCP 一直处于连接状态。

HTTP 协议采用「请求-应答」模式,在普通模式中,每个请求/应答都要新建一个连接,完成之后立即断开;

当使用 Keep-Alive 模式(持久连接),客户端与服务器的连接持续有效,再次请求,不需要重新建立连接。

http1.0 中默认关闭,通过请求头加入「Connection: Keep-Alive」启用;

http1.1中默认启用,通过请求头加入「Connection: close 」关闭。

管线机制

即一次性打包所有请求,不必在传输过程等待服务器响应。

  • 管线机制通过持久连接完成,仅 HTTP/1.1 支持。
  • 初次连接不要启动管线化,服务器不一定支持。

HTTPS

HTTPS 是 HTTP 协议的安全版本。

HTTP 的数据传输是明文的,不安全。HTTPS 使用了 SSL/TLS 协议进行了加密处理。

  • 证书验证阶段采用非对称加密,数据传输阶段采用对称加密。
  • 非对称加密的效率是非常低的,而 http 的应用场景中存在大量的交互


非对称加密:私钥加密的密文,只能公钥解密;公钥加密的密文,只能用私钥解密。

私钥只给一个人,而公钥可以发给所有的人。

所有未采用 HTTPS 的网站,在 Chrome 68 中将标记为不安全网站


链接: https://www.fly63.com/article/detial/7511

HTTPS 常见部署问题及解决方案

到任何有关部署 HTTPS 或 HTTP/2 的问题,都推荐先用 Qualys SSL Labs SSL Server Test 跑个测试,大部分问题都能被诊断出来。

HTTP请求头和响应头部包括的信息有哪些【HTTP请求头各字段解释】

每个HTTP请求和响应都会带有相应的头部信息。默认情况下,在发送XHR请求的同时,还会发送下列头部信息: Accept、Accept-Charset、Accept-Encoding、Connection、Host

服务器响应常用状态码及含义_ajax请求中http返回的状态码大全

HTTP状态码是用以表示网页服务器HTTP响应状态的3位数字代码,其中第一位数字表示响应类别,响应类别从1到5分为五种,分别代表:临时响应、成功、重定向、请求错误、服务器错误。

HTTPS 如何保证数据传输的安全性

在客户端与服务器数据传输的过程中,HTTP协议的传输是不安全的,也就是一般情况下HTTP是明文传输的。但HTTPS协议的数据传输是安全的,也就是说HTTPS数据的传输是经过加密的

http协议的发展历史

在最早的时候,第一个定稿的http协议是http/0.9版本,在这个版本里面,http协议,它的内容,非常非常的简单 只有一个命令。http协议的历史,其中当然还有https,https是http的安全版本,它实际使用的内容跟http/1.1没有很大的区别

axios 模块化封装_对axios的二次封装的实现

Axios 是一个基于 promise 的 HTTP 库 ,使用了axios来进行数据的请求,一般都需要我们对它进行封装处理。下面简单介绍下如何对axios的二次封装的实现,以及在vue中的使用。

HttpClient的3种超时

设置ConnectionPoolTimeout:这定义了从ConnectionManager管理的连接池中取出连接的超时时间,此处设置为1秒。设置ConnectionTimeout:这定义了通过网络与服务器建立连接的超时时间。Httpclient包中通过一个异步线程去创建与服务器的socket连接

HTTP 请求头中的 Remote_Addr,X-Forwarded-For,X-Real-IP

X-Forwarded-For一般是每一个非透明代理转发请求时会将上游服务器的IP地址追加到X-Forwarded-For的后面,使用英文逗号分割;X-Real-IP一般是最后一级代理将上游IP地址添加到该头中;X-Forwarded-For是多个IP地址,而X-Real-IP是一个

HTTP协议中的短轮询、长轮询、长连接和短连接

HTTP协议是基于请求/响应模式的,因此只要服务端给了响应,本次HTTP连接就结束了,根本没有长连接这一说。网络上说HTTP分为长连接和短连接,其实本质上是说的TCP连接。TCP连接是一个双向的通道,它是可以保持一段时间不关闭的,因此TCP连接才有真正的长连接和短连接这一说。

常见HTTP请求错误码

一些常见的状态码为:200 - 服务器成功返回网页;404 - 请求的网页不存在;503 - 服务不可用。1xx(临时响应):表示临时响应并需要请求者继续执行操作的状态代码。2xx (成功):表示成功处理了请求的状态代码。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!