HTTP 协议入门-笔记
1.0版请求格式如下
GET/HTTP/1.0 // 请求命令,必须在尾部添加协议版本(HTTP/1.0)
User-Agent:Mozilla/5.0(Macintosh;Intel Mac OS X 10_10_5) // 描述客户端情况
Accept:*/* // 客户端声明可以接受数据格式
Accept-Encoding: gzip,deflate //客户端说明自己可以接受哪些压缩方法
Connection: keep-alive // 要求服务端不要关闭TCP连接,非标准
回应格式如下
HTTP/1.0 200 OK // 协议版本 状态码 状态描述
Content-Type: text/plain //告诉客户端数据的格式
Content-Length: 139099
Expires: Thu,05 Dec 1997 16:00:00 GMT
Last-Modified: Wed,5 August 1996 15:55:28 GMT
Server: Apache 0.84
Content-Encoding:gzip // 数据压缩方法
Connection: keep-alive // 告诉客户端不关闭TCP连接,非标准
Content-Type的值常见如下
text/plain
text/html
text/css
image/jpeg
image/png
image/svg+xml
audio/mp4
video/mp4
application/javascript
application/pdf
application/zip
application/atom+xml
总称为MIME type,每个值包括一级类型/二级类型
厂商可以自定义类型
MIME type可以在尾部加参数,如下
Content-Type:text/html;charset=utf-8 // 发送的是网页编码是UTF-8
MIME type可以写在网页中如下
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/>
Content-Length: 3456 // 告诉浏览器本次回应的长度,后面属于下一个回应
区分数据包属于哪一个回应,声明本次回应的长度
主要缺点:每个TCP连接只能发送一个请求,发送完毕就关闭
HTTP1.1
引入持久连接,即TCP连接默认不关闭,可以被多个请求复用,在一段时间没有活动后,主动关闭连接。
规范做法客户端在最后一个请求时发送Connection: close,明确告诉服务器关闭连接
大多数浏览器允许同时建立6个持久连接
管道机制在同一个TCP连接里面,客户端可以同时发送多个请求
Transfer-Encoding: chunked // 表明回应将由数量不定的数据块组成
每个非空的数据块之前会与一个16进制的数值表示块的长度,最后一个大小为0表示本次回应数据发送完成
例子:
HTTP/1.1 200 OK
Content-Type: text/plain
Transfer-Encoding: chunked
3
con
2
wo
0
增加了动词方法:PUT,PATCH,HEAD,OPTIONS,DELETE
客户端请求头信息增加Host字段
Host:
www.example.com // 指定服务器的域名
缺点:数据通信是按次序进行的,如果碰到回应特别慢后序请求要排队等着,这就是"队头堵塞"
解决方法一减少请求数
方法二多开持久连接
HTTP/2
是一个二进制协议,头信息和数据体都是二进制,统称为帧(frame)包括头信息帧和数据帧
多工:在一个连接里客户端和浏览器同时发送多个请求或回应,不用按照顺序一一对应。(即服务器同时受到a,b两个请求,先回应a请求发现过程非常耗时,会发送给a已经处理好的部分,然后回应b请求完成后,在发送a剩下部分)
将每个请求或回应的所有数据包称为一个数据流(stream),都有一个独一无二的编号,客户端发出的数据流ID统一为奇数,服务器发出的ID为偶数
客户端可以指定数据流的优先级,优先级越高服务器越早回应
引入了头信息压缩机制(header compression),一方面头信息使用gzip或compress压缩后发送,另一方面客户端和服务端同时维护一张表,所有字段会存在表里生成一个索引,只发送索引号
允许未经请求主动向客户端发送资源即:服务器推送(server push)
场景:客户端请求一个网页里面包含很多静态资源,服务器预期到客户端请求页面后会再请求静态资源,就主动把这些静态资源和网页一起发给客户端了
HTTP 协议入门-笔记的更多相关文章
- React.js入门笔记
# React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...
- redis入门笔记(2)
redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...
- redis入门笔记
redis入门笔记 参考redis实战手册 1. Redis在windows下安装 下载地址:https://github.com/MSOpenTech/redis/tags 安装Redis 1.1. ...
- golang微服务框架go-micro 入门笔记2.1 micro工具之micro api
micro api micro 功能非常强大,本文将详细阐述micro api 命令行的功能 重要的事情说3次 本文全部代码https://idea.techidea8.com/open/idea.s ...
- internet协议入门
前言 劳于读书,逸于作文. 原文地址:internet协议入门 博主博客地址:Damonare的个人博客 博主之前写过一篇博客:网络协议分析,在这篇博客里通过抓包,具体的分析了不同网络协议的传送的数据 ...
- 每天成长一点---WEB前端学习入门笔记
WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...
- ES6入门笔记
ES6入门笔记 02 Let&Const.md 增加了块级作用域. 常量 避免了变量提升 03 变量的解构赋值.md var [a, b, c] = [1, 2, 3]; var [[a,d] ...
- HTTP协议入门要点
应用层协议.基于tcp HTTP/0.9 命令 GET 特点 服务器只能回应HTML字符串 服务器发送完毕后就关闭tcp连接 HTTP/1.0 命令 GET POST HEAD 特点 每次通信都必须包 ...
- [Java入门笔记] 面向对象编程基础(二):方法详解
什么是方法? 简介 在上一篇的blog中,我们知道了方法是类中的一个组成部分,是类或对象的行为特征的抽象. 无论是从语法和功能上来看,方法都有点类似与函数.但是,方法与传统的函数还是有着不同之处: 在 ...
随机推荐
- 用mac的safari浏览器调试ios手机的网页
iOS 6给Safari带来了远程的Web检查器工具. 一.参考链接 ios开发者文档 safari开发者工具 remote debugging safari 二.设置iphone 设置 -> ...
- JPA-style positional param was not an integral ordinal
参数错误 多为SQL语句问题 例如SQL拼装中的空格,换行时首位应多加空格保持语句效果
- GITLAB安装笔记
CentOS 7 最小安装后操作 设置时区timedatectl set-timezone Asia/Shanghai 添加 Gitlab 清华源 vi /etc/yum.repos.d/gitlab ...
- Ubuntu系统的安装(虚拟机) 并配置C/C++编译器
一.系统的初始化配置 1.配置静态IP和DNS 配置静态IP 1.sudo vim /etc/network/interfaces,修改文件内容如下: auto eth0 #表示让网卡开机自动挂载e ...
- git常用命令(todo...)
git init在目录中执行 git init,就可以创建一个 Git 仓库 git add test.javagit add 命令可将该文件添加到缓存(暂存区) git commit test.ja ...
- Node.js中的模块接口module.exports浅析
在写node.js代码时,我们经常需要自己写模块(module).同时还需要在模块最后写好模块接口,声明这个模块对外暴露什么内容.实际上,node.js的模块接口有多种不同写法.这里作者对此做了个简单 ...
- 06-01 Java 二维数组格式、二维数组内存图解、二维数组操作
二维数组格式1 /* 二维数组:就是元素为一维数组的一个数组. 格式1: 数据类型[][] 数组名 = new 数据类型[m][n]; m:表示这个二维数组有多少个一维数组. n:表示每一个一维数组的 ...
- 解决ubuntu安装系统默认没有创建root用户
安装ubuntu操作系统的时候,默认没有设置root账户的步骤!!! 这样在操作系统安装完成之后,就没有root用户, 一般,当前的普通用户,如果需要执行一些命令的时候,只要在命令前边加上sudo就行 ...
- 前端安全 -- XSS攻击
XSS漏洞是最广泛.作用最关键的web安全漏洞之一.在绝大多数网络攻击中都是把XSS作为漏洞链中的第一环,通过XSS,黑客可以得到的最直接利益就是拿到用户浏览器的cookie,从而变相盗取用户的账号密 ...
- MySQL笔记(3)---文件
1.前言 第二章简单记录了一下InnoDB存储引擎的一个基本内容,介绍了保证高效插入的Insert Buffer,change Buffer和确保数据安全的write ahead log以及doubl ...