个人阅读《图解 HTTP》的记录以及总结
以下内容会更深入的了解和学习 HTTP 协议的相关内容
简答的来说就是客户端如何发送以及以怎样的方式发送 HTTP 请求
最常用的就是 POST 和 GET,其他的方式都存在安全性问题
所以下文着重描述 POST 和 GET 方法
GET 请求:获取资源。
GET 方法用来请求访问已被 URI 识别的资源。指定的资源经服务器端解析后返回响应内容。也就是说,如果请求的资源是文本,那就保持原样返回如果是像 CGI(通用网关接口)那样的程序,则返回经过后的输出结果。
POST 请求:传输实体主体。
POST 方法用来传输实体的主体。
虽然用 GET 方法也可以传输实体的主体,但一般不用 GET 方法进行传输,而是用 POST 方法。虽说 POST 的功能与 GET 很相似,但是 POST 的主要目的并不是获取响应的主题内容。
总的来说,GET 用于获取某个内容,POST 用于提交某种数据请求。按照使用场景来说,一般用户注册的内容属于私密的,这应该使用 POST 方式;而针对某一内容的查询,为了快速的响应,可以使用 GET 方式。1. 使用目标不同:
POST 与 GET 都用于获取信息,但是 GET 方式仅仅是查询,并不对服务器上的内容产生任何作用结果;每次 GET 的内容都是相同的。
POST 则常用于发送一定的内容进行某些修改操作。
2. 大小不同:
由于不同的浏览器对 URL 的长度大小有一定的字符限制,因此由于 GET 方式放在 URL 的首部中,自然也跟着首先,但是具体的大小要依浏览器而定。
POST 方式则是把内容放在报文内容中,因此只要报文的内容没有限制,它的大小就没有限制。
3. 安全性不同:
上面也说了 GET 是直接添加到 URL 后面的,直接就可以在 URL 中看到内容。
而 POST 是放在报文内部的,用户无法直接看到。
提出了 HTTP 持久连接的方法,持久连接的特点是,只要任意一端没有明确提出断开连接,则保持 TCP 连接状态。
注:持久连接旨在建立 1 次 TCO 连接后进行多次请求和响应的交互。
持久连接的好处在于减少了 TCP 连接的重复建立和断开所造成的额外开销,减轻了服务区端的负载。另外,减少开销的那部分时间,使 HTTP 请求和响应能够更早地结束,这样 web 页面的显示速度也就相应提高了。
在 HTTP/1.1 中,所有的连接默认都是持久连接,但在 HTTP/1.0 内未标准化。虽然有一部分服务器通过非标准的手段实现了持久连接,但服务器端不一定能够支持持久连接。毫无疑问,除了服务器端,客户端也需要支持持久连接。
持久连接使多数请求以管线化方式发送成为可能。
以前发送请求后需等待并收到响应,才能发送下一个请求。
管线化技术出现后,不用等待响应亦可直接发送下一个请求。
也就是说,无法根据之前的状态进行本次的情求处理。
无状态的 HTTP 协议也是有优点的。由于不必保存状态,自然可减少服务器的 CPU 及内存资源的消耗。
从另一侧面来说,也正是因为 HTTP 协议本身是非常简单的,所以才会被应用在各种场景里。
注:如果让服务器管理全部客户端状态则会成为负担。Cookie 技术通过在请求和响应报文中写入 Cookie 信息来控制客户端的状态。
Cookie 会根据从服务器端发送的响应报文内的一个叫做 Set-Cookie 的首部字段信息,通知客户端保存 Cookie。
当下次客户端再往服务器发送请求时,客户端会自动在请求报文中加上 Cookie 值后发送出去。
服务器端发现客户端发送过来的 Cookie 后,回去检查究竟是从哪个客户端发来的连接请求,然后对比服务器上的记录,最后的到之前的状态信息。
来源: http://www.jianshu.com/p/8246efd900c2