问题
HTTP的状态码有哪些,并用例子说明一下
我的回答
HTTP状态码是服务器对客户端请求的响应码,它们按照不同的功能被分为五大类。我来介绍一下主要的状态码及其实际应用场景:
1xx(信息性状态码):表示请求已接收,需要继续处理。
-
100 Continue:服务器已收到请求的初始部分,客户端应继续发送剩余请求。比如当上传大文件前,客户端可以先发送带有"Expect: 100-continue"头的请求,服务器回应100后再开始上传,避免不必要的数据传输。
-
101 Switching Protocols:服务器同意切换协议。例如,客户端请求从HTTP切换到WebSocket时,服务器会返回101。
2xx(成功状态码):表示请求已成功接收、理解和处理。
-
200 OK:最常见的成功状态码,表示请求成功。例如,当你访问一个网页并成功加载时,服务器返回200。
-
201 Created:请求已完成,并创建了新资源。例如,通过POST请求创建新用户后,返回201和新用户的URL。
-
204 No Content:服务器成功处理了请求,但不需要返回任何内容。例如,删除操作成功后可以返回204。
3xx(重定向状态码):表示客户端需要采取进一步操作才能完成请求。
-
301 Moved Permanently:资源已永久移动到新位置。例如,网站域名变更后,旧域名会返回301并指向新域名,搜索引擎会更新索引。
-
302 Found:资源临时位于不同的URL。例如,未登录用户访问需要权限的页面,被重定向到登录页面。
-
304 Not Modified:资源未修改,可使用缓存版本。例如,浏览器发送带有If-Modified-Since头的请求,如果内容未变,服务器返回304,浏览器使用缓存。
4xx(客户端错误状态码):表示客户端请求有错误。
-
400 Bad Request:请求语法错误。例如,提交表单时数据格式不正确。
-
401 Unauthorized:需要身份验证。例如,访问需要登录的API时未提供有效的认证信息。
-
403 Forbidden:服务器理解请求但拒绝执行。例如,用户尝试访问没有权限的资源。
-
404 Not Found:服务器找不到请求的资源。例如,用户访问了不存在的URL。
-
429 Too Many Requests:用户在给定时间内发送了太多请求。例如,API限制每分钟最多100个请求,超出后返回429。
5xx(服务器错误状态码):表示服务器在处理请求时发生错误。
-
500 Internal Server Error:服务器遇到意外情况。例如,代码中出现未捕获的异常。
-
502 Bad Gateway:作为网关的服务器从上游服务器收到无效响应。例如,Nginx代理后端服务时,后端服务崩溃了。
-
503 Service Unavailable:服务器暂时不可用。例如,服务器正在维护或过载。
-
504 Gateway Timeout:作为网关的服务器未及时从上游服务器收到响应。例如,Nginx等待后端服务响应超时。
在实际工作中,了解这些状态码非常重要。比如,我曾经看到一个问题,用户反馈某些图片无法加载。通过检查网络请求,发现这些请求返回了304状态码,但客户端缓存已损坏。解决方法是在请求URL添加版本参数,强制服务器返回200和完整内容。
正确理解和使用HTTP状态码,可以帮助我们设计更好的API,实现更有效的错误处理,并提高系统的可维护性。