码迷,mamicode.com
首页 > Web开发 > 详细

HTTP协议图解

时间:2017-12-21 12:05:54      阅读:227      评论:0      收藏:0      [点我收藏+]

标签:内容   -128   连接状态   套接字   产生   时间   程序   写入   ima   

1.HTTP简介

http是用于客户端与服务端之间的通信

技术分享图片

实际情况中客户端与服务端角色有可能互换,但从一条通信线路来说服务器端和客户端角色是确定的,http协议知道那个是服务端那个是客户端呢。

http协议规定,请求从客户端发出,服务端响应请求并返回。服务端没有接受请求时是不会发送响应。

技术分享图片

客户端发送给服务器端的请求报文中内容

技术分享图片

GET:请求类型,称之为方法(method);

/index.htm:请求的资源对象,也叫作URI(request-URI);

HTTP/1.1:http的版本号

技术分享图片

服务器端相应内容如下

技术分享图片

技术分享图片

2.HTTP是无状态协议

http协议不保存请求和响应信息

技术分享图片

      每当有新的请求发送时,就会有对应的新响应产生,协议本身不保留之前一切的请求或响应报文的信息,这是为了更快的处理大量事务,确保协议的可伸缩性,而特意把HTTP协议涉及成如此简单的。

     虽然HTTP协议是无状态协议,但是为了实现期望的保持状态功能,于是引入了Cookie技术,有了Cookie就可以管理状态了。

3.HTTP协议的方法

GET:获取资源

GET方法用来请求访问已被URI识别的资源,指定的资源经服务器端解析后返回相应内容。

技术分享图片

技术分享图片

POST:传输实体主体

post方法用来传输实体的主体,虽然get方法也可以传输实体的主体,但是一般情况不使用get方法传输,而是使用post方法传输。post的功能和get很相似,但是post的主要目的并不是获取响应的主体内容。

技术分享图片

技术分享图片

PUT:传输文件

put方法用来传输文件,就像FTP协议的文件上传一样,要求请求报文的主体中包含文件内容,然后保存到请求的URI指定的位置。但是由于HTTP/1.1的PUT方法自身不带验证机制,任何人都可以上传文件,存在安全性问题,因此一般WEB网站不使用该方法。若配合WEB应用程序的验证机制,或架构设计采用REST(REpresentational State Transfer,表征状态转移)标准的同类Web网站,就可能开发使用PUT方法。

技术分享图片

技术分享图片

HEAD:获得报文首部

head方法和get方法一样,知识不返回报文主体部分,用于确认URI的有效性及资源更新的日期时间等。

技术分享图片

DELETE:删除文件

delete方法与put方法相反,用于请求删除指定文件,情况与put方法一样。

技术分享图片

技术分享图片

OPTIONS:询问支持的方法

options方法用来查询针对请求URI的资源支持的方法。

技术分享图片

TRACE:追踪路径

trace方法是让web服务器端将之前的请求通信环回给客户端的方法。发送请求时,在Max-Forwards首部字段中填入数值,没经过一个服务器端就将该数字减1,当数值刚好减到0时,就停止继续传输,最后接收到请求的服务器端则放回状态码200OK的响应。

客户端通过trace方法可以查询发出的请求时怎样被加工修改/窜改的,但是它容易引发XST攻击,通常不会用到。

技术分享图片

CONNECT:要求用隧道协议连接代理

它要求在于代理服务器通信是建立隧道,实现用隧道协议进行TCP通信,主要使用SSL(安全套接字)和TLS(传输层安全)协议把通信内容加密后经网络隧道传输

connect方法格式:

技术分享图片

 

 

 

技术分享图片

技术分享图片

3.持久连接节省通信量

技术分享图片

之前通信情况都是传输较小的文本,所以问题不大,随着HTTP的普及,文档中包含大量图片的情况多了起来,比如一个浏览器浏览一个包含多张图片的页面时,也会请求html页面中包含的其他资源,每次请求都会造成无谓的TCP连接的建立和断开,增加通信量的开销。

技术分享图片

为了解决上述TCP连接的问题,HTTP/1.1提出了持久连接的方法。持久连接的特点就是,只要任意一端没有明确提出断开连接,则保持TCP连接状态。

技术分享图片

管线化

持久连接是的多数请求以管线化方式发送成为可能。之前发送请求后需等待并受到响应才能发送下一个请求,管线化技术出现后不用等待响应可直接发送下一个请求。这样就可以做到同时并行发送多个请求,而不需要一个接一个的等待响应。

技术分享图片

4.Cookie状态管理

Cookie技术通过请求和响应报文中写入Cookie信息来控制客户端的状态

Cookie通过响应报文中的Set-Cookie的首部字段信息,通知客户端保存Cookie,当下次客户端再次发往服务器请求时,客户端会自动在请求报文中加入cookie值。服务器端发现客户端发送来得Cookie后,检查从哪个客户端发来的连接请求,然后对比服务器的记录,最后得到状态信息。

技术分享图片

技术分享图片

技术分享图片

HTTP协议图解

标签:内容   -128   连接状态   套接字   产生   时间   程序   写入   ima   

原文地址:http://www.cnblogs.com/zzp0320/p/8078593.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!