《图解http》

读书笔记: 《图解http》

1:两种获得服务器资源的方法

1 : get 方法 GET方法用来请求访问已被URI识别的资源。指定的资源经服务器端解析后返回响应内容。也就是说,如果请求的资源是文本,那就保持原样返回;如果是像CGI(Common GatewayInterface,通用网关接口)那样的程序,则返回经过执行后的输出结果。

2: post 方法

关于: get 和 post 的区别

知乎上的区别

《图解http》

持久连接节省通信量

以前

《图解http》

现在

《图解http》

持久连接的好处在于减少了TCP连接的重复建立和断开所造成的额外开销,减轻了服务器端的负载。另外,减少开销的那部分时间,使HTTP请求和响应能够更早地结束,这样Web页面的显示速度也就相应提高了

管线化

持久连接使得多数请求以管线化(pipelining)方式发送成为可能。从前发送请求后需等待并收到响应,才能发送下一个请求。管线化技术出现后,不用等待响应亦可直接发送下一个请求。这样就能够做到同时并行发送多个请求,而不需要一个接一个地等待响应了。

《图解http》

使用cookie 进行状态管理

http 是无状态协议它不对之前发生过的请求和响应的状态进行管理。也就是说,无法根据之前的状态进行本次的请求处理。

这会带来麻烦: 每次刷新网页都要重新登录

当然,这也有优点:

由于不必保存状态,自然可减少服务器的CPU及内存资源的消耗。从另一侧面来说,也正是因为HTTP协议本身是非常简单的,所以才会被应用在各种场景里。

所以,我们引入cookie 技术

Cookie技术通过在请求和响应报文中写入Cookie信息来控制客户端的状态。Cookie会根据从服务器端发送的响应报文内的一个叫做Set-Cookie的首部字段信息,通知客户端保存Cookie。当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入Cookie值后发送出去。服务器端发现客户端发送过来的Cookie后,会去检查究竟是从哪一个客户端发来的连接请求,然后对比服务器上的记录,最后得到之前的状态信息

《图解http》

举个例子:

第一次请求报文

《图解http》

响应报文: (注意,此时,已经生成了cookie信息)

《图解http》

第二次请求的报文: (看,已经保存了cookie信息)

《图解http》

http 报文中的http信息:

1: 结构: 《图解http》