HTTP常见的状态码

本文详细介绍了HTTP状态码的分类,包括2开头的成功状态码如200,表示请求已被正常处理;3开头的重定向状态码如304,表示资源未修改;4开头的请求错误状态码如400和403,分别代表错误请求和禁止访问;以及5开头的服务器错误状态码如500,表示服务器内部错误。了解这些状态码有助于诊断和解决网络请求问题。

2开头状态码;2xx (成功)表示成功处理了请求的状态代码;如:200 (成功) 服务器已成功处理了请求。
3开头状态码;3xx (重定向) 表示要完成请求,需要进一步操作。 通常,这些状态代码用来重定向。如:304 (未修改) 自从上次请求后,请求的网页未修改过。 服务器返回此响应时,不会返回网页内容
4开头状态码;4xx(请求错误) 这些状态代码表示请求可能出错,妨碍了服务器的处理;如:400 (错误请求) 服务器不理解请求的语法;403 (禁止) 服务器拒绝请求。404 (未找到) 服务器找不到请求的网页。
5开头状态码;5xx(服务器错误)这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错;如:500 (服务器内部错误) 服务器遇到错误,无法完成请求

### HTTP常见状态及解释 #### 信息性状态 (1xx) 这类状态表示接收到请求并继续处理。 - **100 Continue**: 表示服务器已经收到了请求头部,客户端可以继续发送请求主体[^4]。 - **101 Switching Protocols**: 表明服务器接受客户端的请求,并准备切换协议(例如从HTTP切换到WebSocket)[^4]。 #### 成功状态 (2xx) 此类状态表示请求已被成功接收、理解和处理。 - **200 OK**: 请求成功,服务器返回了请求的资源[^4]。 - **201 Created**: 请求成功,服务器创建了一个新的资源,通常用于`POST`请求。 - **204 No Content**: 请求成功,但没有返回任何内容,常用于`DELETE`请求。 - **206 Partial Content**: 当客户端进行了范围请求时,服务器会成功执行这部分的`GET`请求[^2]。 #### 重定向状态 (3xx) 这些状态告知客户端需采取进一步操作来完成请求。 - **301 Moved Permanently**: 资源已永久移动至新位置,新的URL将在响应的`Location`字段中提供。 - **302 Found**: 资源临时从不同的URI响应请求。 - **304 Not Modified**: 如果资源未被修改,则允许使用缓存版本而不重新下载[^4]。 #### 客户端错误状态 (4xx) 此组状态意味着客户端可能犯了某种错误。 - **400 Bad Request**: 请求无效或格式错误,服务器无法处理该请求[^4]。 - **401 Unauthorized**: 需要身份验证才能访问某些受保护的资源[^4]。 - **403 Forbidden**: 即使提供了正确的凭证,也无权访问特定资源[^4]。 - **404 Not Found**: 所请求的资源在服务器上不存在,可能是地址拼写错误或是资源曾存在但现在已被移除[^3][^4]。 - **429 Too Many Requests**: 客户端在指定时间内发出过多请求,触发速率限制机制。 #### 服务器错误状态 (5xx) 这一系列的状态表明服务器遇到了意外情况,阻止其履行请求。 - **500 Internal Server Error**: 通用错误消息,指出服务器遇到未知问题而无法完成请求。 - **501 Not Implemented**: 服务器不支持实现所需功能以满足请求[^4]。 - **502 Bad Gateway**: 作为网关或代理工作的服务器收到来自上游服务器的有效回复失败[^4]。 - **503 Service Unavailable**: 服务不可用,这通常是由于服务器过载或者正在进行维护所致[^4]。 - **504 Gateway Timeout**: 作为网关或代理工作的服务器未能及时获得来自上游服务器的回应[^4]。 ```python # 示例代展示如何通过Python库requests获取HTTP状态 import requests response = requests.get('https://example.com') print(f'Status Code: {response.status_code}') if response.status_code == 200: print("Request was successful.") elif response.status_code == 404: print("The requested resource could not be found.") else: print("An error occurred with the request.") ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值