• HTTP协议初入门


    Hyper Text Transfer Protocol是基于请求和应答的无状态协议

    一、浏览器向服务器请求一个内容

    一个HTTP请求有四部分组成:请求行、请求头标、空行和请求数据

    1、请求行

    由三个标记组成:请求方法、请求URI和HTTP版本,分别用空格分隔

    例如:GET/index.html HTTP/1.1

    其中HTTP1.0和HTTP1.1规定,请求方法共八种

    • GET,检索URI中标示资源的一个简单请求
    • HEAD,同GET方法,服务器只返回状态行和头标,不返回请求文档
    • POST,服务器接收被写入客户端输入流中的数据请求
    • PUT,服务器保存请求数据作为指定URI新内容的请求
    • DELETE,服务器删除URI中命名的资源的请求
    • OPTIONS,关于服务器支持的请求方法信息的请求
    • TRACE,web服务器反馈HTTP请求和其头标的请求
    • CONNECT,已文档化但当前未实现的一个方法,预留做隧道处理

    在web应用中,通常只使用GET和POST请求

    2、请求头标

    通知服务器关于客户端的功能和标识,由关键字/值对组成,每行一对,用:分隔,典型的请求头标有:

    • User-Agent,客户端厂家和版本
    • Accept,客户端可识别的内容类型列表
    • Content-Length,附加到请求的数据字节数

    3、空行。最后一个请求头标之后是一个空行,发送回车符和退行,通知服务器以下不再有头标

    4、请求数据。使用POST发送的数据

    二、服务器响应

    web服务器收到请求后,解析请求。如果请求的是静态资源,则将请求的资源返回给浏览器,如果请求的是动态的服务器程序,如servlet、JSP、ASP、CGI等,则在服务器端运行程序后返回运行的结果。

    一个响应由四个部分组成

    1、状态行。由三个标记组成

    • HTTP版本
    • 响应代码:三位的数字代码,指出请求的结果
    • 响应描述:为响应代码的解释

    如:HTTP/.1 200 OK

    附:HTTP响应状态码(转):

    1**:请求收到,继续处理
    2**:操作成功收到,分析、接受
    3**:完成此请求必须进一步处理
    4**:请求包含一个错误语法或不能完成
    5**:服务器执行一个完全有效请求失败

    100——客户必须继续发出请求
    101——客户要求服务器根据请求转换HTTP协议版本

    200——交易成功
    201——提示知道新文件的URL

    202——接受和处理、但处理未完成
    203——返回信息不确定或不完整
    204——请求收到,但返回信息为空
    205——服务器完成了请求,用户代理必须复位当前已经浏览过的文件
    206——服务器已经完成了部分用户的GET请求

    300——请求的资源可在多处得到
    301——删除请求数据
    302——在其他地址发现了请求数据
    303——建议客户访问其他URL或访问方式

    304——客户端已经执行了GET,但文件未变化
    305——请求的资源必须从服务器指定的地址得到
    306——前一版本HTTP中使用的代码,现行版本中不再使用
    307——申明请求的资源临时性删除

    400——错误请求,如语法错误
    401——请求授权失败
    402——保留有效ChargeTo头响应
    403——请求不允许
    404——没有发现文件、查询或URl
    405——用户在Request-Line字段定义的方法不允许
    406——根据用户发送的Accept拖,请求资源不可访问
    407——类似401,用户必须首先在代理服务器上得到授权
    408——客户端没有在用户指定的饿时间内完成请求
    409——对当前资源状态,请求不能完成
    410——服务器上不再有此资源且无进一步的参考地址
    411——服务器拒绝用户定义的Content-Length属性请求
    412——一个或多个请求头字段在当前请求中错误
    413——请求的资源大于服务器允许的大小
    414——请求的资源URL长于服务器允许的长度
    415——请求资源不支持请求项目格式
    416——请求中包含Range请求头字段,在当前请求资源范围内没有range指示值,请求
    也不包含If-Range请求头字段
    417——服务器不满足请求Expect头字段指定的期望值,如果是代理服务器,可能是下
    一级服务器不能满足请求

    500——服务器产生内部错误
    501——服务器不支持请求的函数

    502——服务器暂时不可用,有时是为了防止发生系统过载
    503——服务器过载或暂停维修
    504——关口过载,服务器使用另一个关口或服务来响应用户,等待时间设定值较长
    505——服务器不支持或拒绝支请求头中指定的HTTP版本

    6xx  Proxy Error
    600  Unparseable Response Headers (Squid-specific)

    详细解释:

    100  Continue  初始的请求已经接受,客户应当继续发送请求的其余部分。(HTTP 1.1新)

    101  Switching Protocols  服务器将遵从客户的请求转换到另外一种协议(HTTP 1.1新)

    200  OK  一切正常,对GET和POST请求的应答文档跟在后面。

    201  Created  服务器已经创建了文档,Location头给出了它的URL。

    202  Accepted  已经接受请求,但处理尚未完成。

    203  Non-Authoritative Information  文档已经正常地返回,但一些应答头可能不正确,因为使用的是文档的拷贝(HTTP 1.1新)。

    204 No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。

    205  Reset Content  没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容(HTTP 1.1新)。

    206  Partial Content  客户发送了一个带有Range头的GET请求,服务器完成了它(HTTP 1.1新)。

    300  Multiple Choices  客户请求的文档可以在多个位置找到,这些位置已经在返回的文档内列出。如果服务器要提出优先选择,则应该在Location应答头指明。  

    301  Moved Permanently  客户请求的文档在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL。

    302  Found  类似于301,但新的URL应该被视为临时性的替代,而不是永久性的。注意,在HTTP1.0中对应的状态信息是“Moved Temporatily”。 出现该状态代码时,浏览器能够自动访问新的URL,因此它是一个很有用的状态代码。

    注意这个状态代码有时候可以和301替换使用。例如,如果浏览器错误地请求http://host/~user(缺少了后面的斜杠),有的服务器返回301,有的则返回302。

    严格地说,我们只能假定只有当原来的请求是GET时浏览器才会自动重定向。请参见307。 303 See Other 类似于301/302,不同之处在于,如果原来的请求是POST,Location头指定的重定向目标文档应该通过GET提取(HTTP 1.1新)。

    304  Not Modified  客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档)。服务器告诉客户,原来缓冲的文档还可以继续使用。

    305  Use Proxy  客户请求的文档应该通过Location头所指明的代理服务器提取(HTTP 1.1新)。

    307  Temporary Redirect  和302(Found)相同。许多浏览器会错误地响应302应答进行重定向,即使原来的请求是POST,即使它实际上只能在POST请求的应答是303时 才能重定向。由于这个原因,HTTP 1.1新增了307,以便更加清除地区分几个状态代码:当出现303应答时,浏览器可以跟随重定向的GET和POST请求;如果是307应答,则浏览器只 能跟随对GET请求的重定向。(HTTP 1.1新)

    400  Bad Request  请求出现语法错误。

    401  Unauthorized  客户试图未经授权访问受密码保护的页面。应答中会包含一个WWW-Authenticate头,浏览器据此显示用户名字/密码对话框,然后在填写合适的Authorization头后再次发出请求。

    403  Forbidden  资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。

    404  Not Found  无法找到指定位置的资源。这也是一个常用的应答。

    405  Method Not Allowed  请求方法(GET、POST、HEAD、Delete、PUT、TRACE等)对指定的资源不适用。(HTTP 1.1新)

    406  Not Acceptable  指定的资源已经找到,但它的MIME类型和客户在Accpet头中所指定的不兼容(HTTP 1.1新)。

    407  Proxy Authentication Required  类似于401,表示客户必须先经过代理服务器的授权。(HTTP 1.1新)

    408  Request Timeout  在服务器许可的等待时间内,客户一直没有发出任何请求。客户可以在以后重复同一请求。(HTTP 1.1新)

    409 Conflict  通常和PUT请求有关。由于请求和资源的当前状态相冲突,因此请求不能成功。(HTTP 1.1新)

    410  Gone  所请求的文档已经不再可用,而且服务器不知道应该重定向到哪一个地址。它和404的不同在于,返回407表示文档永久地离开了指定的位置,而404表示由于未知的原因文档不可用。(HTTP 1.1新)

    411  Length Required  服务器不能处理请求,除非客户发送一个Content-Length头。(HTTP 1.1新)

    412  Precondition Failed  请求头中指定的一些前提条件失败(HTTP 1.1新)。

    413  Request Entity Too Large  目标文档的大小超过服务器当前愿意处理的大小。如果服务器认为自己能够稍后再处理该请求,则应该提供一个Retry-After头(HTTP 1.1新)。

    414  Request URI Too Long  URI太长(HTTP 1.1新)。

    416  Requested Range Not Satisfiable  服务器不能满足客户在请求中指定的Range头。(HTTP 1.1新)

    500  Internal Server Error  服务器遇到了意料不到的情况,不能完成客户的请求。

    501  Not Implemented  服务器不支持实现请求所需要的功能。例如,客户发出了一个服务器不支持的PUT请求。

    502 Bad Gateway  服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。

    503 Service Unavailable  服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。

    504  Gateway Timeout  由作为代理或网关的服务器使用,表示不能及时地从远程服务器获得应答。(HTTP 1.1新)

    505  HTTP Version Not Supported  服务器不支持请求中所指明的HTTP版本。(HTTP 1.1新)

    6xx  Proxy Error
    600  Unparseable Response Headers (Squid-specific)

    2、响应头标。指出服务器的功能,标示出响应数据的细节。

    3、空行。最后一个响应头标之后是一个空行,发送回车符和退行,通知服务器以下不再有头标

    4、响应数据。HTML和图像等,也就是HTML本身。

    三、服务器发完响应后关闭连接,浏览器解析响应内容。

    • 先解析状态行,查看请求是否成功的状态代码
    • 解析每一个响应头标,头标告知一下为若干字节的HTML
    • 读取响应数据HTML,根据HTML的语法和语义对其进行格式化后,在浏览器窗口中显示

    示例:

    四、POST和GET

    GET:获得静态资源,将请求附加在URI后面作为参数传递,如获得动态资源,使用参数,如:http://www.domain.com?search=jead

    POST:请求动态资源,将请求作为数据放在请求体中传送的。

  • 相关阅读:
    IntelliJ IDEA 安装和破解教程
    IntelliJ IDEA 快捷键
    分布式事务框架-seata初识
    Spring超详细总结
    spring注解之@Import注解的三种使用方式
    双亲委托模型
    日志管理-log4j与slf4j的使用
    最详细的自定义Spring Boot Starter开发教程
    深入JVM(二)JVM概述
    一篇长文说 git 基础
  • 原文地址:https://www.cnblogs.com/JoannaQ/p/2709059.html
Copyright © 2020-2023  润新知