zoukankan      html  css  js  c++  java
  • HTTP协议

    1.HTTP协议的主要特点

    简单快速:统一资源服务

    灵活:一个http类型能完成不同的数据传输

    无连接:连接一次就会断掉,不会保持连接

    无状态:客户端和服务端是两种身份,不能区分两次连接者的身份

    2.HTTP报文的组成部分

    HTTP报文包括两个部分:请求报文(1.请求行:包含http方法,页面地址,http协议以及版本      2.请求头:key,value值,告诉服务端要哪些内容   3.空行:告诉服务端空行之后就是请求体 4.请求体)和相应报文(状态行 响应头 空行 相应体)

    3.HTTP方法

    GET       获取资源

    POST     传输资源

    PUT        更新资源

    DELETE 删除资源

    HEAD     获得报文首部

    4.POST和GET的区别

    get在浏览器回退时时是无害的,而post会再次提交请求

    get产生的url地址可以被收藏,而post不可以

    get请求会被浏览器主动缓存,而post不会,除非手动设置

    get请求只能进行url编码,而post支持多种编码方式

    get请求参数会被完整保留在浏览器历史记录里,而post中的参数不会被保留

    get请求在url中传送的参数是有长度限制的,而post没有限制

    对于参数的数据类型,get只接受ASCLL字符,而post没有限制

    get比post更不安全,因为参数直接暴露在url上,所以不能用来传递敏感信息

    get参数通过传递,post放在Request body中

    5.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: 请求未完成,服务器临时过载或当机,一段时间后可能恢复正常

    6.什么是持久连接

    在HTTP/1.0中,默认使用的是短连接。也就是说,浏览器和服务器每进行一次HTTP操作,就建立一次连接,但任务结束就中断连接。如果客户端浏览器访问的某个HTML或其他类型的 Web页中包含有其他的Web资源,如JavaScript文件、图像文件、CSS文件等;当浏览器每遇到这样一个Web资源,就会建立一个HTTP会话。但从 HTTP/1.1起,默认使用长连接,用以保持连接特性。使用长连接的HTTP协议,会在响应头有加入这行代码: Connection:keep-alive

    7.什么是管线化

    HTTP管线化是将多个HTTP要求(request)整批提交的技术,而在传送过程中不需先等待服务端的回应。管线化机制须通过永久连接(persistent connection)完成,仅HTTP/1.1支持此技术(HTTP/1.0不支持),并且只有GET和HEAD要求可以进行管线化,而POST则有所限制。此外,初次创建连接时也不应启动管线机制,因为对方(服务器)不一定支持HTTP/1.1版本的协议。

  • 相关阅读:
    SpringBoot学习笔记
    2021牛客多校第一场 I题(DP)
    CSS小结
    AOP小结
    IOC容器小结
    Educational Codeforces Round 56 (Rated for Div. 2) G题(线段树,曼哈顿距离)
    Codeforces Round #656 (Div. 3) E. Directing Edges(拓扑排序)
    Educational Codeforces Round 101 (Rated for Div. 2) E
    [FJOI2017]矩阵填数 (容斥原理)
    优秀代码样板收集计划(python)
  • 原文地址:https://www.cnblogs.com/leiting/p/8262009.html
Copyright © 2011-2022 走看看