网络状态码-经验笔记
网络状态码-经验笔记
引言
在网络通信中,HTTP(Hypertext Transfer Protocol)状态码是服务器向客户端(通常是Web浏览器)发送响应时所包含的重要信息之一。
这些状态码指示了客户端请求的结果。
了解并正确使用这些状态码对于构建健壮的Web应用和服务至关重要。
HTTP状态码分类
HTTP状态码分为五大类,每种类别代表了不同含义:
- 1xx Informational(信息性状态码)
- 2xx Successful(成功状态码)
- 3xx Redirection(重定向状态码)
- 4xx Client Error(客户端错误状态码)
- 5xx Server Error(服务器错误状态码)
1xx Informational
这类状态码用于传输过程中的临时响应,客户端应继续处理请求或等待进一步的信息。
- 100 Continue:指示客户端继续发送请求的剩余部分。
- 101 Switching Protocols:服务器正在切换协议,遵照Upgrade请求头字段的值。
2xx Successful
这类状态码表示请求已被成功接收、理解和接受。
- 200 OK:标准的响应成功状态码。
- 201 Created:请求成功且创建了一个新的资源。
- 202 Accepted:请求已接受待处理,但处理尚未完成。
- 204 No Content:请求已成功处理,但没有返回任何内容。
- 206 Partial Content:服务器已成功处理了部分GET请求。
3xx Redirection
这类状态码指示需要客户端采取进一步的动作才能完成请求。
- 300 Multiple Choices:请求的资源对应多个位置,客户端可以选择其中一个。
- 301 Moved Permanently:请求的资源已永久移动到新位置。
- 302 Found (Temporary Redirect):请求的资源临时位于不同的URI,未来请求应使用原来的URI。
- 303 See Other:客户端应通过GET方法重定向到另一个URI。
- 304 Not Modified:客户端已拥有资源的最新版本,无需再次下载。
- 307 Temporary Redirect:请求的资源临时位于不同的URI,但未来请求应使用原来的URI。
- 308 Permanent Redirect:请求的资源已永久移动到新位置,客户端应使用新的URI。
4xx Client Error
这类状态码表示客户端发送的请求有错误,服务器无法处理。
- 400 Bad Request:服务器无法理解请求的格式。
- 401 Unauthorized:请求需要用户身份验证。
- 403 Forbidden:服务器理解请求客户端的请求,但拒绝执行此请求。
- 404 Not Found:请求的资源不存在。
- 405 Method Not Allowed:请求的方法(如POST、GET等)不被允许用于请求的资源。
- 409 Conflict:请求与当前资源状态冲突。
- 415 Unsupported Media Type:服务器拒绝请求,因为请求实体的格式不受请求的目标资源支持。
- 429 Too Many Requests:用户已发出太多请求,在指定时间内不能再发请求。
5xx Server Error
这类状态码表示服务器在处理请求时出现了错误。
- 500 Internal Server Error:服务器遇到了一个未曾预料的情况,无法完成对请求的处理。
- 501 Not Implemented:服务器不支持请求的功能。
- 502 Bad Gateway:作为网关或代理工作的服务器从上游服务器收到了无效的响应。
- 503 Service Unavailable:服务器目前无法使用(可能是服务器过载或进行维护)。
- 504 Gateway Timeout:作为网关或代理工作的服务器从上游服务器等待响应的时间太长。
- 505 HTTP Version Not Supported:服务器不支持请求中使用的HTTP协议版本。
使用场景示例
- 创建资源:当客户端发送一个POST请求创建一个新资源时,如果创建成功,服务器应返回201 Created状态码,并在响应头中包含新资源的URI。
- 获取资源:如果客户端发送GET请求来获取一个存在的资源,服务器应该返回200 OK状态码和资源数据。
- 资源不存在:如果客户端尝试访问一个不存在的资源,服务器应该返回404 Not Found状态码。
- 资源更新:当客户端发送PUT或PATCH请求更新资源时,如果更新成功,服务器应该返回200 OK状态码。
- 资源删除:当客户端发送DELETE请求删除资源时,如果删除成功,服务器应该返回204 No Content状态码。
- 身份验证:如果客户端没有提供必要的身份验证信息,服务器应该返回401 Unauthorized状态码。
- 权限不足:如果客户端尝试访问受限资源但没有足够的权限,服务器应该返回403 Forbidden状态码。
- 服务器错误:如果服务器在处理请求时遇到问题,比如内部错误或数据库问题,应该返回500 Internal Server Error状态码。
实现细节
后端编程
在后端开发中,可以通过以下方式设置HTTP状态码:
-
Node.js (Express):
app.get('/example', function(req, res) {res.status(200).send('Resource found'); }); -
Python (Flask):
from flask import Flask, jsonify, make_responseapp = Flask(__name__)@app.route('/example') def example():response = make_response(jsonify({'message': 'Resource found'}), 200)return response -
Java (Spring Boot):
import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController;@RestController public class ExampleController {@GetMapping("/example")public ResponseEntity<String> example() {return new ResponseEntity<>("Resource found", HttpStatus.OK);} }
错误处理
为了确保能够有效地处理错误并返回适当的HTTP状态码,你可以在后端代码中实现错误处理机制。这通常涉及到使用异常处理来捕获错误,并根据错误类型设置不同的状态码。
例子:异常处理
from flask import Flask, jsonify, make_responseapp = Flask(__name__)@app.errorhandler(404)
def not_found(error):return make_response(jsonify({'error': 'Not found'}), 404)@app.errorhandler(Exception)
def handle_exception(e):code = 500if isinstance(e, ValueError):code = 400return make_response(jsonify({'error': str(e)}), code)
结论
正确使用HTTP状态码对于构建健壮的Web应用和服务至关重要。
通过在代码中显式地设置状态码,你可以覆盖服务器默认的行为,并提供更具体和有意义的反馈给客户端。
此外,良好的错误处理机制可以帮助提高应用程序的稳定性和用户体验。
相关文章:
网络状态码-经验笔记
网络状态码-经验笔记 引言 在网络通信中,HTTP(Hypertext Transfer Protocol)状态码是服务器向客户端(通常是Web浏览器)发送响应时所包含的重要信息之一。 这些状态码指示了客户端请求的结果。 了解并正确使用这些状态…...
c++ 实现 actor 框架
服务端:https://github.com/xukeawsl/coro_actor 客户端:https://github.com/xukeawsl/coro_actor_client...
应对猫咪掉毛挑战,希喂、小米热门宠物空气净化器实测功效PK
随着养宠人群的增多,铲屎官们的需求日益增长,市场上出现了很多品牌的宠物空气净化器。然而,产品质量参差不齐,给消费者选择带来不少困难。劣质宠物空气净化器不仅无法有效去除宠物毛发、皮屑、异味及空气中的有害微粒,…...
0002 保险会计及其特殊性
保险会计是将会计理论专门应用于保险公司的专业会计领域,它是会计学的一个重要分支。作为一个分支,保险会计具有独特的特性,这些特性主要表现在以下几个方面: 产品的无形性:保险产品本质上是一种无形的商品,…...
ChatTTS:终极文本转语音工具,支持API!
ChatTTS:终极文本转语音工具,支持API! 文本转语音(TTS)系统的发展已经取得了长足的进步。从最初的机械化、平坦的声音,到如今听起来令人惊讶的人声,ChatTTS作为这一领域的新成员,旨…...
VUE和Element Plus
1.VUE 1.下载和配置环境 使用vue编程,我们需要使用到的编程软件是vs code,还需要使用node.js,这个的作用就类似于JDK,当我们都下载好之后,winR键打开命令提示符,我们在这里可以查看版本, npm…...
Python学习笔记(五)
""" 演示tuple元组的定义和操作 """# 元组一旦定义完成,就不可修改 # 定义元组 # t1 (1, "Hello", True) # t2 () # 定义空元组 # t3 tuple() #定义空元组 # print(f"t1的类型是:{type(t1)}, 内容是&…...
Linux企业级应用(一)构建企业级Linux应用平台:全面指南
文章目录 构建企业级Linux应用平台:全面指南前言1. Linux企业级应用简介2. 构建企业级网站应用平台使用LNMP架构构建Web服务器部署MySQL数据库主从复制与读写分离 3. 实施虚拟化技术部署KVM虚拟化平台使用LVS和Keepalived实现负载均衡与高可用性 4. 文件系统与分布式…...
LeetCode112 路径总和
前言 题目: 112. 路径总和 文档: 代码随想录——路径总和 编程语言: C 解题状态: 成功解答! 思路 比较简单的一个思路是遍历所有的路径,求和后再查找目标值。但是,最好的方法是一边遍历&#x…...
TI AWR1843 毫米波雷达实物展示
引言 随着自动驾驶、工业自动化以及智能交通系统的快速发展,雷达传感器在现代科技中的重要性日益提升。毫米波雷达凭借其高精度测距、抗干扰能力强等特点,逐渐成为各类感知系统中的关键技术。德州仪器(TI)推出的 AWR1843 毫米波雷…...
前端JS总结(下)之事件操作
目录 前言 事件基础 事件的三部分: 常见的事件: 鼠标事件: 键盘事件: 表单事件: onfocus和onblur:获取焦点和失去焦点 onselect:选中单行文本框/多行文本框中的内容 onchangeÿ…...
如何妙用哈希表来优化遍历查找过程?刷题感悟总结,c++实现
先上题目 题目链接:题目链接 这题我最先想到的就是前缀和a,构造好了以后就遍历每一个[l,r]数组(满足题目要求的连续区间数组),奈何倒数第二个样例时间超限 先给出原思路代码 class Solution { public:int subarray…...
【设计模式】漫谈设计模式
这篇文章里说一下对设计模式的个人的理解。本篇文章更类似于随笔而非技术文档。 设计模式最早是在上个世纪就被人提出来了,如今被奉为圣经,也就是GOF等人写的《设计模式》,其中的设计模式,是指导开发者如何进行开发出高内聚、低耦…...
第N5周:Pytorch文本分类入门
本文为365天深度学习训练营 中的学习记录博客原作者:K同学啊 任务: ●1. 了解文本分类的基本流程 ●2. 学习常用数据清洗方法 ●3. 学习如何使用jieba实现英文分词 ●4. 学习如何构建文本向量 一、前期准备 环境安装 这是一个使用PyTorch实现的简单文…...
SpringBoot 自定义 starter
1. 官方文档 SpringBoot 版本 2.6.13,相关链接 Developing with Spring Boot 1.1 什么是 Starter Starters are a set of convenient dependency descriptors that you can include in your application. You get a one-stop shop for all the Spring and relate…...
TDengine Invalid data format 问题定位
Invalid data format 看语义是数据类型不符,通常这个报错出现在使用行协议写入时。 如果是批量数据写入,想定位是哪条语句的问题,需要查看客户端日志。 如何确定使用的是哪个日志 lsof -p pidof taosadapter | grep taoslog如果没有安装lso…...
Spring Boot 使用 MongoDB 教程
🍁 作者:知识浅谈,CSDN签约讲师,CSDN博客专家,华为云云享专家,阿里云专家博主 📌 擅长领域:全栈工程师、爬虫、ACM算法 🔥 微信:zsqtcyw 联系我领取学习资料 …...
Python办公自动化:使用openpyxl 创建与保存 Excel 工作簿
1 创建新的工作簿 在开始任何 Excel 操作之前,首先需要创建一个工作簿。openpyxl 提供了简单的接口来创建新的工作簿。 创建一个空白的工作簿 我们可以使用 openpyxl.Workbook() 来创建一个新的空白工作簿。以下是一个简单的示例: import openpyxl# …...
【张】#11 Union 共用体
Union 共用体可以存储不同的数据类型,但只能同时存储其中的一种类型。 #include <iostream> using namespace std;struct Product {char productName[20];int type;//1 int ,else charunion{int id_int;char id_chars[20];}; };int main(){Product product; …...
Xcode 在原生集成flutter项目
笔者公司有一个从2017年就开始开发的iOS和安卓原生项目,现在计划从外到内开始进行项目迁徙。 1》从gitee拉取flutter端的代码;(Android报错Exception: Podfile missing) 2》替换Xcode里的cocopods里Podfile的路径 然后报警 然后…...
浪潮服务器硬盘红灯报警?手把手教你更换RAID阵列故障盘(附同步失败解决方案)
浪潮服务器硬盘红灯报警全流程处置指南:从故障诊断到阵列重建 当浪潮服务器的硬盘指示灯突然亮起刺眼的红色,大多数运维人员的第一反应往往是心头一紧。这种视觉警报不仅意味着硬件故障,更可能预示着数据丢失的风险。不同于普通PC的硬盘故障…...
告别Linux卡顿!用RK3562的M0核跑RT-Thread,实现实时控制与Linux并行运行
RK3562多核异构开发实战:用M0核实现Linux与RT-Thread的完美协同 在智能家居控制器项目中,我们遇到了一个典型难题——当Linux系统处理图形界面和网络通信时,电机的实时控制会出现明显延迟。传统解决方案需要两套独立硬件,直到我们…...
VSCode远程开发必备:SSH端口转发一键配置指南(含常见问题排查)
VSCode远程开发实战:SSH端口转发高效配置与深度排错 当你在咖啡厅修改代码时,远程服务器上的数据库服务突然需要紧急调试;当团队协作时,同事的内网API接口需要临时开放给你测试——这些场景下,SSH端口转发就像一把瑞士…...
OpenClaw 实战:3 分钟打造一个真正能「干活」的 AI 员工
OpenClaw 实战:3 分钟打造一个真正能「干活」的 AI 员工 市面上关于 OpenClaw 入门的文章一抓一大把,但真正能落地应用的实践却少之又少。经过半个多月的深度测试,我从搜索精度到人格配置进行了全量跑测,整理出这份让 Agent 真正…...
ollama-QwQ-32B量化部署:在4GB内存设备运行OpenClaw的配置
ollama-QwQ-32B量化部署:在4GB内存设备运行OpenClaw的配置 1. 为什么要在低配设备上折腾大模型? 去年冬天,我在树莓派上第一次尝试部署OpenClaw时,被现实狠狠教育了一顿——32GB内存的笔记本跑得飞起,换到4GB的树莓派…...
OpenClaw技能市场巡礼:Qwen3-32B生态的十大实用工具
OpenClaw技能市场巡礼:Qwen3-32B生态的十大实用工具 1. 为什么需要关注OpenClaw技能市场? 第一次接触OpenClaw时,我被它"让AI直接操作电脑"的理念震撼了。但真正让我决定长期使用的,却是它背后那个不断壮大的技能市场…...
YOLOv5 模型训练避坑大全:从数据集制作到解决 mAP 为 0 的常见报错
YOLOv5 模型训练避坑实战指南:从数据标注到调参优化的全流程解决方案 当你第一次成功运行YOLOv5的官方示例时,那种成就感可能让你误以为目标检测模型训练已经掌握。但现实往往很骨感——当换上自己的数据集后,各种报错接踵而至:显…...
VMware Workstation 16保姆级教程:Windows Server 2019虚拟机安装全流程(含避坑指南)
VMware Workstation 16实战指南:Windows Server 2019虚拟机高效部署与深度优化 在数字化转型浪潮中,本地虚拟化环境搭建已成为开发者和运维人员的核心技能。作为业界标杆的VMware Workstation 16与Windows Server 2019的组合,能够完美模拟企业…...
AI 创作者指南:04.AI写作:从草稿到润色的全流程协作
第4篇AI写作:从草稿到润色的全流程协作 第一部分创意引擎学完,你现在灵感满池、选题稳稳、观点锋利,是不是已经跃跃欲试想动笔了?😊 来,正式进入第二部分:AI作为写作与表达助手! 今天第4篇——AI写作:从草稿到润色的全流程协作。 咱们还是老朋友喝茶模式:AI不是让你…...
Imaginary跨域资源共享(CORS)终极配置指南:前端图像处理无障碍集成
Imaginary跨域资源共享(CORS)终极配置指南:前端图像处理无障碍集成 【免费下载链接】imaginary Fast, simple, scalable, Docker-ready HTTP microservice for high-level image processing 项目地址: https://gitcode.com/gh_mirrors/im/imaginary Imaginar…...
