HTTP协议 | 青训营笔记

88 阅读2分钟

HTTP协议

这是我参与 「第五届青训营」\color{#1d7dfa}{「第五届青训营」} 伴学笔记创作活动的第5天。

一、初识HTTP协议

  • Hyper Text Transfer Protocol 超文本传输协议
    HTTP 是一个基于 TCP/IP 通信协议来传递数据(HTML 文件、图片文件、查询结果等)。
    HTTP 的 URL 是由 http:// 起始与默认使用端口80。
  • 报文分析\color{#047fff}{报文分析} HTTP 协议中共定义了八种方法或者叫“动作”来表明对 Request-URI 指定的资源的不同操作方式,具体介绍如下:

OPTIONS\color{#ff7d00}{OPTIONS}:返回服务器针对特定资源所支持的HTTP请求方法。也可以利用向Web服务器发送'*'的请求来测试服务器的功能性。

HEAD\color{#ff7d00}{HEAD}:向服务器索要与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以在不必传输整个响应内容的情况下,就可以获取包含在响应消息头中的元信息。

GET\color{#ff7d00}{GET}:向特定的资源发出请求。

POST\color{#ff7d00}{POST}:向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的创建和/或已有资源的修改。

PUT\color{#ff7d00}{PUT}:向指定资源位置上传其最新内容。

DELETE\color{#ff7d00}{DELETE}:请求服务器删除 Request-URI 所标识的资源。

TRACE\color{#ff7d00}{TRACE}:回显服务器收到的请求,主要用于测试或诊断。

CONNECT\color{#ff7d00}{CONNECT}:HTTP/1.1 协议中预留给能够将连接改为管道方式的代理服务器。

虽然 HTTP 的请求方式有 8 种,但是我们在实际应用中常用的也就是 get 和 post,其他请求方式也都可以通过这两种方式间接的来实现。

  • 状态码
    200 0K-客户端请求成功
    301-资源(网页等)被永久转移到其它URL
    302-临时跳转 401 Unauthorized-请求未经授权
    404-请求资源不存在,可能是输入了错误的URL
    500-服务器内部发生了不可预期的错误
    504 Gateway Timeout-网关或者代理的服务器无法在规定的时间内获得想要的响应。

http1.png

  • 常用请求头

http7.png

  • 常用响应头

http4.png

  • 缓存 (1)强缓存

httpo14.png (2)协商缓存

http33.png

http56.png

二、HTTPS概述

HTTPS经由HTTP进行通信,但利用SSL/TLS来加密数据包,HTTPS开发的主要目的,是提供对网站服务器的身份认证,保护交换资料的隐私与完整性。HTTPS的URL是由 https:// 起始与默认使用端口443。

http-56.png

  • 对称加密 加密和解密都是使用同一个密钥。
  • 非对称加密 加密和解密需要使用两个不同的密钥:公钥(public key)和私钥(private key)

http-41.png