列举HTTP中常见的状态码

本文详细解读了HTTP状态码,包括2xx成功、3xx重定向和4xx/5xx错误代码,帮助理解服务器响应和客户端请求的关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1xx(临时响应)
表示临时响应并需要请求者继续执行操作的状态代码。

代码 说明
100 (继续) 请求者应当继续提出请求。服务器返回此代码表示已收到请求的第一部分,正在等待其余部分。
101 (切换协议) 请求者已要求服务器切换协议,服务器已确认并准备切换。

2xx (成功)
表示成功处理了请求的状态代码。

代码 说明
200 (成功) 服务器已成功处理了请求。通常,这表示服务器提供了请求的网页。
201 (已创建) 请求成功并且服务器创建了新的资源。
202 (已接受) 服务器已接受请求,但尚未处理。
203 (非授权信息) 服务器已成功处理了请求,但返回的信息可能来自另一来源。
204 (无内容) 服务器成功处理了请求,但没有返回任何内容。
205 (重置内容) 服务器成功处理了请求,但没有返回任何内容。
206 (部分内容) 服务器成功处理了部分 GET 请求。

3xx (重定向)
表示要完成请求,需要进一步操作。 通常,这些状态代码用来重定向。

代码 说明
300 (多种选择) 针对请求,服务器可执行多种操作。服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择。
301 (永久移动) 请求的网页已永久移动到新位置。服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。
302 (临时移动) 服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
303 (查看其他位置) 请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。
304 (未修改) 自从上次请求后,请求的网页未修改过。服务器返回此响应时,不会返回网页内容。
305 (使用代理) 请求者只能使用代理访问请求的网页。如果服务器返回此响应,还表示请求者应使用代理。
307 (临时重定向) 服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。

4xx(请求错误)
这些状态代码表示请求可能出错,妨碍了服务器的处理。

代码 说明
400 (错误请求) 服务器不理解请求的语法。
401 (未授权) 请求要求身份验证。 对于需要登录的网页,服务器可能返回此响应。
403 (禁止) 服务器拒绝请求。
404 (未找到) 服务器找不到请求的网页。
405 (方法禁用) 禁用请求中指定的方法。
406 (不接受) 无法使用请求的内容特性响应请求的网页。
407 (需要代理授权) 此状态代码与 401(未授权)类似,但指定请求者应当授权使用代理。
408 (请求超时) 服务器等候请求时发生超时。
409 (冲突) 服务器在完成请求时发生冲突。服务器必须在响应中包含有关冲突的信息。
410 (已删除) 如果请求的资源已永久删除,服务器就会返回此响应。
411 (需要有效长度) 服务器不接受不含有效内容长度标头字段的请求。
412 (未满足前提条件) 服务器未满足请求者在请求中设置的其中一个前提条件。
413 (请求实体过大) 服务器无法处理请求,因为请求实体过大,超出服务器的处理能力。
414 (请求的 URI 过长) 请求的 URI(通常为网址)过长,服务器无法处理。
415 (不支持的媒体类型) 请求的格式不受请求页面的支持。
416 (请求范围不符合要求) 如果页面无法提供请求的范围,则服务器会返回此状态代码。
417 (未满足期望值) 服务器未满足"期望"请求标头字段的要求。

5xx(服务器错误)
这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。

代码 说明
500 (服务器内部错误) 服务器遇到错误,无法完成请求。
501 (尚未实施) 服务器不具备完成请求的功能。例如,服务器无法识别请求方法时可能会返回此代码。
502 (错误网关) 服务器作为网关或代理,从上游服务器收到无效响应。
503 (服务不可用) 服务器目前无法使用(由于超载或停机维护)。通常,这只是暂时状态。
504 (网关超时) 服务器作为网关或代理,但是没有及时从上游服务器收到请求。
505 (HTTP 版本不受支持) 服务器不支持请求中所用的 HTTP 协议版本。

HttpWatch状态码Result is

200 - 服务器成功返回网页,客户端请求已成功。
302 - 对象临时移动。服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
304 - 属于重定向。自上次请求后,请求的网页未修改过。服务器返回此响应时,不会返回网页内容。
401 - 未授权。请求要求身份验证。 对于需要登录的网页,服务器可能返回此响应。
404 - 未找到。服务器找不到请求的网页。
2xx - 成功。表示服务器成功地接受了客户端请求。
3xx - 重定向。表示要完成请求,需要进一步操作。客户端浏览器必须采取更多操作来实现请求。例如,浏览器可能不得不请求服务器上的不同的页面,或通过代理服务器重复该请求。
4xx - 请求错误。这些状态代码表示请求可能出错,妨碍了服务器的处理。
5xx - 服务器错误。表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。

<think>嗯,用户之前让我详细解释了iperf3的测试报告参数,现在又想要了解常见HTTP状态。我需要先确定用户的需求是什么。可能他正在学习网络相关的知识,或者在工作中遇到了需要调试HTTP请求的情况。HTTP状态对于Web开发和网络问题排查非常重要,所以用户可能希望有一个清晰的列表来帮助理解不同的响应状态。 首先,我应该按照状态的分类来组织信息,比如1xx到5xx,每个类别代表不同类型的响应。用户可能需要知道每个状态的具体含义,以及常见的例子,这样他们在实际应用中能更快地识别问题所在。比如,404表示资源未找到,500是服务器内部错误,这些都是开发中经常遇到的。 另外,用户可能还需要一些使用注意事项,比如如何处理这些状态,或者在开发时应该注意什么。例如,3xx的重定向状态需要关注Location头,而4xx错误可能需要检查客户端请求是否正确。此外,用户可能对状态的扩展有所好奇,比如自定义状态,但需要提醒他们遵循RFC标准以确保兼容性。 我还应该考虑用户是否有更深层的需求,比如他们是否在调试某个具体的API,或者遇到了性能问题。不过根据当前的问题,提供全面且分类清晰的常见状态列表应该足够。需要确保每个状态的解释简洁明了,避免使用过于专业的术语,让不同层次的用户都能理解。 最后,可能需要补充一些实际例子,比如常见的200 OK,301永久重定向,403禁止访问等,这样用户能更容易记忆和应用。同时,提醒用户注意状态的官方定义和实际应用中的差异,比如有些服务器可能自定义错误消息,但状态的大类是不变的。总结时,强调正确理解和处理状态对Web开发和维护的重要性,帮助用户提升问题诊断效率。</think>以下是常见HTTP状态分类说明及典型示例: ######################### ### 一、信息响应(1xx) ######################### 1. **100 Continue** 服务器已收到请求头,客户端应继续发送请求体(用于大文件上传前验证) 2. **101 Switching Protocols** 服务器同意协议切换(如从HTTP升级到WebSocket) $$ \text{使用场景} = \begin{cases} \text{协议升级} \\ \text{HTTP/2连接建立} \end{cases} $$ ######################### ### 二、成功响应(2xx) ######################### 1. **200 OK** 请求成功(GET返回资源/POST返回操作结果) 2. **201 Created** 资源创建成功(常见于POST/PUT请求) 3. **204 No Content** 请求成功但无返回内容(常见于DELETE请求) 4. **206 Partial Content** 分块传输成功(用于大文件断点续传) ######################### ### 三、重定向(3xx) ######################### $$ \text{重定向类型} = \begin{cases} \text{永久(301/308)} \\ \text{临时(302/303/307)} \end{cases} $$ 1. **301 Moved Permanently** 资源永久迁移(搜索引擎更新链接) 2. **302 Found** 临时重定向(早期规范要求方法变更为GET,现建议用307/308) 3. **304 Not Modified** 资源未修改(配合If-Modified-Since头使用) 4. **307 Temporary Redirect** 临时重定向且保持请求方法 5. **308 Permanent Redirect** 永久重定向且保持请求方法 ######################### ### 四、客户端错误(4xx) ######################### 1. **400 Bad Request** 请求语法错误(如JSON格式错误) 2. **401 Unauthorized** 需要身份验证(未携带有效凭证) 3. **403 Forbidden** 服务器理解请求但拒绝执行(权限不足) 4. **404 Not Found** 资源不存在(URL路径错误) 5. **405 Method Not Allowed** 请求方法不被支持(如对只读资源执行PUT) 6. **429 Too Many Requests** 请求频率超限(API限流) ######################### ### 五、服务端错误(5xx) ######################### 1. **500 Internal Server Error** 通用服务器错误(未捕获的异常) 2. **502 Bad Gateway** 网关服务器收到无效响应(上游服务故障) 3. **503 Service Unavailable** 服务暂时不可用(维护/过载) 4. **504 Gateway Timeout** 网关服务器请求超时(上游服务响应延迟) ######################### ### 六、使用注意事项 ######################### 1. **状态覆盖原则** - 2xx表示成功完成请求动作 - 4xx需明确错误类型,避免用400替代具体错误 2. **重定向处理** - 301/308需要更新书签 - 302/307需检查`Location`响应头 3. **调试建议** - 4xx错误优先检查请求头/参数 - 5xx错误需查看服务端日志 示例场景: - 上传文件失败:413 Payload Too Large - 跨域请求被拒:403 Forbidden(未配置CORS) - 支付接口重复提交:409 Conflict 特殊状态扩展: - 418 I'm a teapot(RFC 2324彩蛋状态) - 451 Unavailable For Legal Reasons(法律限制访问)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@百思不得奇解

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值