HTTP特点
-
支持客户/服务器模式
-
客户/服务器模式工作的方式是由客户端向服务器发出请求,服务器端响应请求,并进行响应服务
-
简单快速
-
客户向服务器请求服务时,只需传送请求方法和路径
-
请求方法常用的有GET,HEAD,POST。每种方法规定了客户与服务器练习的类型不同
-
由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度很快
-
灵活
-
HTTP允许传输任意类型的数据对象
-
正在传输的类型由Content-Type加以标记
-
无连接
-
无连接的含义就是限制每次连接只处理一个请求
-
服务器处理完客户的请求 ,并收到客户的应答后,即断开连接
-
采用这种方式可以节省传输时间
-
无状态
-
HTTP协议是无状态协议
-
无状态是指协议对于事物处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传。这些可能导致每次连接传送的数据量增大
-
在服务器不需要先前信息时它的应答就较快
URI与URL
-首先,我们要知道输入到浏览器的Web地址应该叫URL(其实是URI)
- URI:一个紧凑的字符串用来标示抽象或物理资源
- [ ]URI可以进一步被分为定位符,名字或俩者都是
- 术语"Uniform Resource Locator"(URL)是URI的子集,除了确定一个资源,还提供一种定位该资源的主要访问机制(如其网络“位置”)
URI可以分为URL,URN或同时具备locators和names特性的一个东西
URN作用就好像一个人的名字,URL就像一个人的地址
URN确定了东西 的身份,URL提供了找到他的方式
URL是URI的一种,但不是所有的URI都是URL
URI和URL最大的差别就是 "访问机制"
URN是唯一标示的一部分,是身份信息
ftp://ftp.is.za/rfc/2134.txt————URL
http://wwww.iqiyi.org/ers————URL
tel:+2-313-421-421————URI
urn:oasis:names:wafads:doocbook:dec:xml:2.3.2————URN
HTTP——请求报文
- 通常用到的报文头
首部字段名 | 说明 |
---|---|
Cache-Control | 控制缓存的行为 |
Connection | 逐跳首部、连接的管理 |
Date | 创建报文的日期时间 |
Pragma | 报文指令 |
Trailer | 报文末端的首部一览 |
Transfer-Encoding | 指定报文主体的传输编码方式 |
Upgrade | 升级为其他协议 |
Via | 代理服务器的相关信息 |
Warn | 错误通知 |
-
请求报文头
-
响应报文头
-
实体报文头
ACCEPT
- 作用:浏览器端可以接受的媒体类型
Accept:text/html 代表浏览器可以接受服务器回发的类型为text/html也就是我们常说的html文档,如果服务器无法返回text/html类型的数据,服务器应该返回一个406错误(Non Acceptable)
如果想要给显示的媒体类型增加优先级,则使用q=来额外表示权重值。权重值q的范围是0~1(可精确到小数点后三位),且1为最大值。不指定权重 q值时,默认权重q=1.0.当服务器提供多种内容时,将会首先返回权重值最高的媒体类型。
Accept:*/* 代表浏览器可以处理所有类型
Accept-Encoding
- 作用:浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持啥压缩方法(gzip,deflate)
Accept-Encoding:gzip,deflate
Accept-Language
- 作用:浏览器申明自己接收的语言
Accept-Language:zh-cn,zh;q=0.7,en-us,en;q=0.3
客户端在服务器有中文版资源的情况下,会请求其返回中文版对应的响应,没有中文版时,则请求返回英文版响应
Connection
- Connection:keep-alive 当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接
- Connection:close 代表一个Request完成后,客户端和服务器之间用于传输HTTP数据的TCP连接会关闭,当客户端再次发送Request,需要重新建立TCP连接
Host
- 作用:请求报文头域主要用于指定被请求资源的Internet主机和端口号,它通常从HTTP URL中提取出来的
我们在浏览器中输入:http://www.fljf.com:8080
浏览器发送的请求消息中,就会包括Host请求报头域,如下:
Host:www.fljf.com:8080
Referer
- 当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器借此可以获取一些信息用于处理
User-Agent
- 作用:告诉HTTP服务器,客户端使用的操作系统和浏览器的名称和版本
- 很多情况下我们会通过User-Agnet来判断浏览器类型,从而进行不同的兼容设计
Content-Type
- 作用:说明了报文体内对象的媒体类型
- 作用:说明了报文体内对象的媒体类型
HTTP报文结构分析-响应报文
HTTP请求方法剖析
-
HTTP常用方法
Ⅰ GET
Ⅱ POST
Ⅲ PUT
Ⅳ HEAD
Ⅴ DELETE
Ⅵ OPTIONS
Ⅶ TRACE
Ⅷ CONNECT -
GET方法用来请求访问已被URI识别的资源
-
指定的资源经服务器解析后返回响应内容
-
GET方法也可以用来提交表单和其他数据
http://loaclhost/login.php?username=aa&password=1234
从上面的URL请求中,很容易就可以辨认出表单提交的内容
同时,浏览器对于提交URL的长度也有所限制
-
POST方法与GET功能类似,一般用来传输实体的主体
-
POST方法的主要目的不是获取响应主体的内容
-
PUT方法从客户端向服务器传送的数据取代指定的文档的内容
-
PUT方法与POST方法最大的不同是:PUT是幂等的,而POST是不幂等的
-
因此,我们更多时候将PUT方法用作传输资源
-
HEAD
-
类似于GET请求,只不过返回的响应中没有具体的内容 ,用于获取报头
-
DELETE
-
请求服务器删除指定的资源
-
OPTIONS
-
用于查询针对请求URI指定资源支持的方法
-
TRACE/CONNECT
-
TRACE:回显服务器收到的请求,主要用于测试或诊断
-
CONNECT
-
开启一个客户端与所请求资源之间的双向沟通的通道 ,它可以用来创建隧道