美文网首页
http协议类

http协议类

作者: vavid | 来源:发表于2018-07-17 17:33 被阅读0次

    一、HTTP协议的主要特点
    1、简单快速 2、灵活 3、无连接 4、无状态

    二、HTTP报文的组成部分
    请求报文:请求行、请求头、空行、请求体
    响应报文:状态行、响应头、空行、相应体

    三、HTTP方法
    GET-------------------> 获取资源
    POST ------------------> 传输资源
    PUT-------------------> 更新资源
    DELETE-------------------> 删除资源
    HEAD-------------------> 获取报文首部
    OPTIONS------------------->预检请求
    注意:对那些可能对服务器数据产生副作用的 HTTP 请求方法(特别是 GET 以外的 HTTP 请求,或者搭配某些 MIME 类型的 POST 请求),浏览器必须首先使用 OPTIONS 方法发起一个预检请求(preflight request),从而获知服务端是否允许该跨域请求。服务器确认允许之后,才发起实际的 HTTP 请求。

    四、POST与GET的区别
    GET在浏览器回退时是无害的,而POST会再次提交请求
    GET产生的URL地址可以被收藏,而POST不可以
    GET请求会被浏览器主动缓存,而POST不会,除非手动设置
    GET请求只能进行URL编码,而POST支持多种编码方式
    GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留
    GET请求在RUL中传送的参数是有长度限制的,而POST没有限制
    对参数的数据类型,GET只接受ASCII字符,而POST没有限制
    GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息
    GET参数通过URL传递,POST放置在Request body中

    五、HTTP状态码
    1xx:指示信息 — 表示请求已接收,继续处理
    2xx:成功 — 表示请求已被成功接收
    3xx:重定向 — 要完成请求必须进行更进一步的操作
    4xx:客户端错误 — 请求有语法错误或请求无法实现
    5xx:服务器错误 — 服务器未能实现合法的请求


    200 OK:客户端请求成功
    206 Partial Content:客户发送了一个带有Range头的GET请求,服务器完成了它
    301 Moved Permanently:所请求的页面已经转移至新的URL
    302 Found:所请求的页面已经临时转移至新的URL
    304 Not Modified:客户端有缓冲的文档并发出了一个条件性的请求,服务器告诉客户,原来缓冲的文档还可以继续使用
    400 Bad Request:客户端请求有语法错误,不能被服务器所理解
    401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
    403 Forbidden:对被请求页面的访问被禁止
    404 Not Found:请求资源不存在
    500 Internal Server Error:服务器发生不可预期的错误原来缓冲的文档还可以继续使用
    503 Server Unavailable:请求未完成,服务器临时过载或当机,一段时间后可能恢复正常。

    六、什么是持久连接
    HTTP协议采用"请求—应答"模式,当使用普通模式,即非Keep-Alive模式时,每个请求/应答客户和都完全都要新建一个连接,完成之后立即断开连接(HTTP协议为无连接的协议)
    当使用Keep-Alive模式(由称持久连接、连接重用)时,Keep-Alive功能使客户端到服务器端的连接持续有效,当出现对服务器的后继请求时,Keep-Alive功能避免了建立或者重新建立连接

    七、什么是管线化
    在使用持久连接的情况下,某个连接上消息的传递类似于
    请求1 -> 响应1 -> 请求2 -> 响应2 -> 请求3 -> 响应3
    某个连接上的消息变成了类似这样
    请求1 -> 请求2 -> 请求3 -> 响应1 -> 响应2 -> 响应3

    管线化机制通过持久连接完成,仅HTTP/1.1支持此技术
    只有GET和HEAD请求可以进行管线化,而POST则有所限制
    初次创建连接时不应启动管线机制,因为对方(服务器端)不一定支持HTTP/1.1版本的协议
    管线化不会影响响应到来的吮吸,如上面的例子所示,响应返回的吮吸并未改变
    HTTP/1.1要求服务器端支持管线化,但并不要求服务器端也对响应进行管线化处理,只是要求对于管线化的请求不失败即可
    由于上面提到的服务器端问题,开启管线化很可能并不会带来大幅度的性能提升,而且很多服务器端和代理程序对管线化的支持并不好,因此现代浏览器如Chrome 和 Firefox 默认并未开启管线化支持

    相关文章

      网友评论

          本文标题:http协议类

          本文链接:https://www.haomeiwen.com/subject/ywegpftx.html