http协议中各个响应状态返回值(200、400、404、500等)的含义

转载:https://blog.youkuaiyun.com/Amandazhouzhou/article/details/89210459

1.该类型状态码表示接收到请求并且继续处理

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

2.该类型状态码表示动作被成功接收、理解和接受。

  • 200,表明该请求被成功地完成,所请求的资源发送到客户端。
  • 201,提示知道新文件的URL。
  • 202,接受并处理,但处理未完成。
  • 203,返回信息不确定或不完整。
  • 204,收到请求,但返回信息为空.
  • 205,服务器完成了请求,用户必须复位当前已经浏览过的文件。
  • 206,服务器已经完成了部分用户的GET请求。

3.该类型状态码表示为了完成指定的动作,必须接受进一步处理。

  • 300,请求的资源可在多处获得。
  • 301,本网页被永久性转移到另一个URL。
  • 302,请求的网页被重定向到新的地址。
  • 303,建议用户访问其他URL或访问方式。
  • 304,自从上次请求后,请求的网页未修改过。
  • 305,请求的资源必须从服务器指定的地址获得。
  • 306,前一版本HTTP中使用的代码,现已不再使用。
  • 307,声明请求的资源临时性删除。

4.该类型状态码表示请求包含错误语法或不能正确执行。

  • 400,客户端请求有语法错误。
  • 401,请求未经授权。
  • 402,保留有效ChargeTo头响应。
  • 403,禁止访问,服务器收到请求,但拒绝提供服务。
  • 404,可连接服务器,但服务器无法取得所请求的网页,请求资源不存在。
  • 405,用户在Request-Line字段定义的方法不被允许。
  • 406,根据用户发送的Accept,请求资源不可访问。
  • 407,类似401,用户必须首先在代理服务器上取得授权。
  • 408,客户端没有在用户指定的时间内完成请求。
  • 409,对当前资源状态,请求不能完成。
  • 410,服务器上不再有此资源。
  • 411,服务器拒绝用户定义的Content-Length属性请求。
  • 412,一个或多个请求头字段在当前请求中错误。
  • 413,请求的资源大于服务器允许的大小。
  • 414,请求的资源URL长于服务器允许的长度。
  • 415,请求资源不支持请求项目格式。
  • 416,请求中包含Range请求头字段,在当前请求资源范围内没有range指示值。
  • 417,服务器不满足请求Expect头字段指定的期望值。

5.该类型状态码表示服务器或网关错误。

  • 500,服务器错误。
  • 501,服务器不支持请求的功能。
  • 502,网关错误。
  • 503,无法获得服务。
  • 504,网关超时。
  • 505,不支持的http版本。

补充:

http请求方法:

用来表明对指定资源的操作方式。常用的请求方法有:

OPTIONS,返回服务器针对特定资源所支持的HTTP请求方法。
HEAD,与GET请求一致,只不过不会返回响应体。
GET,请求指定的资源。
POST,向指定资源提交数据进行处理请求,数据包含在请求体中,可能会导致新资源的创建或已有资源的修改。
PUT,向指定资源位置上传最新内容。
DELETE,请求服务器删除所标识的资源。
GET和POST方法的主要区别:

GET提交的数据会放在URL之后,以?分割URL和传输数据,参数之间以&相连。POST把提交的数据放在Body中。
GET提交的数据大小最多1024字节。POST提交的数据大小没有限制。
GET提交数据时,会出现在URL上。POST则不会出现在URL上。

HTTP请求响应中,如果返回多个`data`字段,通常意味着服务器在响应体中包含多个数据块。这种情况可能出现在以下几种场景: 1. **分页数据**:服务器可能会通过多次响应返回分页数据,每个响应中的`data`字段包含一页的数据。 2. **流式传输**:某些服务会采用流式传输方式发送数据,将大块数据分割为多个部分逐步发送,每个部分作为一个独立的`data`字段进行传输。 3. **批量操作结果**:例如Elasticsearch等搜索引擎支持批量插入或查询操作,每个操作的结果可能会被单独标记为一个`data`字段[^3]。 ### 如何解析多个`data`字段 解析包含多个`data`字段的HTTP响应时,需要根据具体的协议格式和应用场景采取相应的处理方法: - **JSON结构**:如果响应内容以JSON格式编码,且包含多个`data`字段,则可以通过数组形式表示多个数据对象。例如: ```json { "code": 200, "message": "Success", "data": [ {"id": 1, "name": "Item 1"}, {"id": 2, "name": "Item 2"} ] } ``` 在此情况下,可以使用标准的JSON解析库来提取所有`data`字段的内容,并按需遍历处理。 - **分块传输编码(Chunked Transfer Encoding)**:对于采用分块传输的响应,每个数据块可能是一个独立的`data`片段。这种情况下,需要逐块读取并合并,直到接收到结束标识符为止[^2]。 - **多部分消息(multipart/form-data 或 multipart/byteranges)**:如果响应使用了多部分内容类型,则每个部分都会包含自己的头部信息和数据体。解析此类响应时,需要按照MIME规则对各个部分进行解码[^2]。 ### 多个`data`字段的含义 - **数据分片**:当服务器端无法一次性返回全部数据时,可能会将数据分片传输。每个`data`字段代表一个数据片段。 - **批量操作结果**:在执行批量操作时,每个操作的结果可能作为单独的`data`字段返回。例如,在向Elasticsearch批量插入文档时,每个插入操作的结果会被单独标记[^3]。 - **错误信息与成功信息分离**:某些API设计中,可能会通过不同的`data`字段区分成功的结果与错误的信息。 ### 处理方法 - **逐块处理**:对于流式传输或分块传输的响应,应采用逐块读取的方式处理,确保内存占用可控。 - **聚合数据**:若多个`data`字段代表的是同一类数据的不同部分,可以在客户端将其聚合为一个完整的数据集后再进行后续处理。 - **异步处理**:在处理大量数据或长时间运行的操作时,可以考虑使用异步编程模型,以便在等待下一个`data`字段到达的同时继续执行其他任务。 - **状态跟踪**:在处理多部分响应时,保持对当前处理状态的跟踪非常重要,特别是在需要跨多个`data`字段维护上下文的情况下。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值