超文本传输协议(HTTP)是一个用于传输超媒体文档(例如 HTML)的应用层协议。它是为 Web 浏览器与 Web 服务器之间的通信而设计的,但也可以用于其他目的。HTTP 遵循经典的客户端-服务端模型,客户端打开一个连接以发出请求,然后等待它收到服务器端响应。HTTP 是无状态协议,这意味着服务器不会在两个请求之间保留任何数据(状态)。该协议虽然通常基于 TCP/IP 层,但可以在任何可靠的传输层上使用;也就是说,不像 UDP,它是一个不会静默丢失消息的协议。RUDP——作为 UDP 的可靠化升级版本——是一种合适的替代选择。
HTTP 概述
介绍了客户端-服务器端协议的基本特征:它能够做什么以及它的设计意图。
HTTP 缓存
缓存对高速 Web 站点来说是非常之重要的。这篇文章阐述了不同种类的缓存以及如何配置 HTTP 首部来控制它们。
HTTP Cookie
RFC 6265 定义了 cookie 是怎样工作的。当接收到一个 HTTP请求时,服务器可以在响应中发送一个 Set-Cookie 首部字段。接着,对于同一台服务器发起的每一个请求,客户端都会在 HTTP 请求头中以字段 Cookie 的形式将 cookie 的值发送过去。 此外,还可以指定一个过期时间,也可以指定一个特定的域名和路径中使用。
HTTP 访问控制(CORS)
跨站 HTTP 请求就是从另一个域名,而不是资源所在的域名发起的 HTTP 请求。举例来说,在域名 A (http://www.xxx.com/) 的 HTML 页面上使用 img 元素 (<img src="http://www.xxx.com/image.jpg">) 来请求域名 B (http://www.bbb.com/) 上的图片资源。这在当前的 web 页面上很常见 —— 页面通过跨域规则加载 CSS 样式表,图片,脚本以及其他资源。
HTTP 的演变
简单描述了从早期版本的 HTTP 到现在的 HTTP/2 以及未来的 HTTP 这个过程中发生的变更。
HTTP 消息
描述了 HTTP/1.x 和 HTTP/2.x 中不同种类消息的类型和结构。
典型的 HTTP 会话
展现并解释了一个常见的 HTTP 会话流程。
HTTP/1.x 中的连接管理
描述了在 HTTP/1.x 中的三种连接管理模型,以及它们的优势和劣势。
HTTP 首部
HTTP 消息首部被用来描述资源信息,或是客户端和服务器的行为。自定义的专有首部可以加上 'X-' 前缀; 其他的可以在 IANA registry 找到,其原始定义在 RFC 4229。IANA 同时也维护着一份 registry of proposed new HTTP message headers。
HTTP 请求方法
可以使用 HTTP: GET,POST 方法来完成不同操作,同时也有一些其他的方法,如 OPTIONS,DELETE 和 TRACE。
HTTP 状态返回码
HTTP 状态返回码用来表示指定的 HTTP 请求是否成功完成。响应被分为 5 种类型: 消息型响应,成功响应,重定向,客户端错误和服务器错误。
CSP 指令
Content-Security-Policy 响应头字段允许站点的管理者控制页面上哪些资源能够被用户代理程序加载。除了少数例外,此策略主要涉及源服务器和脚本终端。
工具与资源
有助于理解和调试 HTTP 连接的工具和资源。
Firefox 开发者工具
网络监视器
RedBot
用于检查 Cache 相关的 HTTP 头的工具。