Furion友好异常

news2024/9/23 1:25:22

一、一图流

在这里插入图片描述

二、注册友好异常服务

在 Furion 框架中,友好异常处理服务可以通过 AddFriendlyException 方法进行注册,这个方法通常在项目的启动配置中使用。

using Microsoft.Extensions.DependencyInjection;

namespace YourNamespace
{
    [AppStartup(800)] // 定义应用启动顺序
    public sealed class YourStartupClass : AppStartup
    {
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllers()
                    .AddFriendlyException(); // 注册友好异常处理服务
        }
    }
}

注意AddFriendlyException() 方法需要在 services.AddControllers() 之后注册。

三、抛出友好异常

Furion 提供了 Oops.Oh 方法,允许开发者在代码中轻松抛出友好异常。Oops.Oh 可以接受不同的参数来定制异常信息。

示例1:简单抛出异常

using Furion.DynamicApiController;
using Furion.FriendlyException;

namespace YourNamespace
{
    public class YourAppService : IDynamicApiController
    {
        public int Get(int id)
        {
            if (id < 3)
            {
                throw Oops.Oh($"{id} 不能小于3");
            }

            return id;
        }
    }
}

示例2:抛出特定类型的异常

using Furion.DynamicApiController;
using Furion.FriendlyException;
using System;

namespace YourNamespace
{
    public class YourAppService : IDynamicApiController
    {
        public int Get(int id)
        {
            if (id < 3)
            {
                throw Oops.Oh($"{id} 不能小于3。", typeof(InvalidOperationException));
            }

            return id;
        }
    }
}

四、使用自定义异常信息

为了更好地管理和重用异常信息,可以使用枚举来定义异常信息,并通过 Oops.Oh 方法抛出这些自定义的异常。

创建异常信息枚举

using Furion.FriendlyException;

namespace YourNamespace
{
    [ErrorCodeType] // 标记枚举为错误代码类型
    public enum ErrorCodes
    {
        [ErrorCodeItemMetadata("{0} 不能小于 {1}")]
        InvalidId,

        [ErrorCodeItemMetadata("数据不存在")]
        DataNotFound,

        [ErrorCodeItemMetadata("{0} 发现 {1} 个异常", "系统", 2)]
        MultipleErrors,

        [ErrorCodeItemMetadata("服务器运行异常", ErrorCode = "Error")]
        ServerError
    }
}

使用自定义异常信息

using Furion.DynamicApiController;
using Furion.FriendlyException;

namespace YourNamespace
{
    public class YourAppService : IDynamicApiController
    {
        public int Get(int id)
        {
            if (id < 3)
            {
                throw Oops.Oh(ErrorCodes.InvalidId, id, 3); // 使用自定义错误代码
            }

            return id;
        }
    }
}

五、异常方法重试

在某些情况下,你可能希望对特定的操作进行多次尝试,直到成功或达到最大尝试次数。Furion 提供了 Retry.Invoke 方法来实现这一需求。

示例:异常方法重试

using Furion.FriendlyException;

public class YourService
{
    public void PerformOperation()
    {
        Oops.Retry(() => 
        {
            // 需要重试的操作
            DoSomething();
        }, retryCount: 3, delayMilliseconds: 1000); // 重试3次,每次间隔1秒
    }

    private void DoSomething()
    {
        // 可能抛出异常的代码
    }
}

六、全局异常处理提供器

Furion 提供了实现 IGlobalExceptionHandler 接口的方式,开发者可以通过此接口自定义全局异常处理逻辑,例如记录日志。

using Furion.DependencyInjection;
using Furion.FriendlyException;
using Microsoft.AspNetCore.Mvc.Filters;
using System.Threading.Tasks;

namespace YourNamespace
{
    public class LogExceptionHandler : IGlobalExceptionHandler, ISingleton
    {
        public Task OnExceptionAsync(ExceptionContext context)
        {
            // 在这里记录异常日志
            LogException(context.Exception);

            return Task.CompletedTask;
        }

        private void LogException(Exception exception)
        {
            // 记录异常到日志系统
        }
    }
}

七、配置异常信息文件

通过 appsettings.json 文件,可以动态配置异常信息,即使在运行时也可以方便地调整异常提示。

{
  "ErrorCodeMessageSettings": {
    "Definitions": [
      ["5000", "{0} 不能小于 {1}"],
      ["5001", "操作失败,请稍后重试"],
      ["5002", "Oops! 出错了"]
    ]
  }
}

使用配置的异常信息

using Furion.DynamicApiController;
using Furion.FriendlyException;

namespace YourNamespace
{
    public class YourAppService : IDynamicApiController
    {
        public int Get(int id)
        {
            if (id < 3)
            {
                throw Oops.Oh(5000, id, 3); // 使用配置文件中的5000异常码
            }

            return id;
        }
    }
}

八、自定义友好异常的其他功能

[IfException] 特性

如果需要覆盖默认的异常信息,可以使用 [IfException] 特性。

using Furion.DynamicApiController;
using Furion.FriendlyException;

namespace YourNamespace
{
    public class YourAppService : IDynamicApiController
    {
        [IfException(ErrorCodes.InvalidId, ErrorMessage = "自定义的错误信息:{0} 不能小于 {1}")]
        public int Get(int id)
        {
            if (id < 3)
            {
                throw Oops.Oh(ErrorCodes.InvalidId, id, 3);
            }

            return id;
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2117425.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

组件拆分综合案例——商城首页

欢迎大家订阅【Vue2Vue3】入门到实践 专栏&#xff0c;开启你的 Vue 学习之旅&#xff01; 文章目录 一、传统的 HTML/CSS 写法二、现代的 Vue.js 组件化写法 本篇文章参考黑马程序员 【组件拆分综合案例——商城首页】 一、传统的 HTML/CSS 写法 App.vue文件&#xff1a; &l…

JAVA便捷同城圈信息汇聚服务预约任务发布平台系统小程序源码

​便捷同城圈&#xff0c;信息汇聚服务预约任务发布平台系统 &#x1f3d9;️ 开篇&#xff1a;同城生活&#xff0c;一键触达 在这个快节奏的城市里&#xff0c;你是否经常为找不到靠谱的服务、错过重要的信息或是有小任务却找不到人帮忙而烦恼&#xff1f;别担心&#xff0c…

运维学习————GitLab的搭建和使用

目录 一、简介 1、概念 2、 好处 3、优势 二、 下载安装 1、准备工作 2、下载安装 3、配置 三、常用命令 四、GitLab的使用 1、解决无法访问 ​编辑2、修改密码 3、gitlab结合linux的使用 1、使用用户名和密码操作 2、使用ssh秘钥操作 4、卸载GitLab 5、gi…

铁路故障多分类数据集(猫脸码客 第183期 )

铁路故障多分类数据集研究&#xff1a;基于深度学习的ECARRNet模型 引言 东南亚地区以其庞大的铁路网络著称&#xff0c;这一基础设施在促进区域经济发展、加强国家间联系方面发挥着不可替代的作用。然而&#xff0c;随着铁路网络的不断扩展和运营时间的增长&#xff0c;铁路…

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆&#xff0c;该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使…

oracle TAB$ 基表删除恢复

接客户服务请求&#xff0c;说是一个好久没有用的数据库在打开时遭遇ora-00600 16703 1403 28 错误&#xff0c;这中一看就是oracle 的tab$基表被删除了。 客户环境 aix 平台&#xff1b; 索性数据库比较小只有10G左右&#xff0c;懒得的弄bbed&#xff0c;直接oracle dul 抽…

【信创】Linux终端禁用USB存储 _ 统信 _ 麒麟 _ 方德

原文链接&#xff1a;【信创】Linux终端禁用USB存储 | 统信 | 麒麟 | 方德 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于在Linux终端下禁用USB存储设备的文章。禁用USB存储设备可以提高系统的安全性&#xff0c;防止未经授权的人员将数据拷贝到外部存储设备或…

VMware Fusion 13.6 OEM BIOS 2.7 - 在 macOS 中运行 Windows 虚拟机的最佳方式

VMware Fusion 13.6 OEM BIOS 2.7 - 在 macOS 中运行 Windows 虚拟机的最佳方式 VMware Fusion 13 原版 App 中集成 OEM BIOS 请访问原文链接&#xff1a;https://sysin.cn/blog/vmware-fusion-13-oem/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主…

中国家庭收入调查(CHIP)数据合集(1988-2018年)

中国家庭收入调查&#xff08;CHIP&#xff09;是一项重要的社会学研究资源&#xff0c;它通过入户调查的方式收集了包含家庭收支信息以及其他相关的家庭和个人信息。CHIP数据合集涵盖了多个年份&#xff0c;包括2018、2013、2008、2007、2002、1999、1995、1988年&#xff0c;…

词嵌入(一):基于矩阵分解的静态词嵌入(VSM、TF-IDF、SVD)

文章目录 一、从几种直观思路的不足谈到理想的Word Representation1.1 独热编码1.2 共现矩阵1.3 理想的Word Representation应当满足的要求 二、静态词嵌入与动态词嵌入三、基于矩阵分解的静态词嵌入3.1 Distributional Hypothesis3.2 向量空间模型&#xff08;Vector Space Mo…

【详解】网络隔离环境下,跨网文件交换存在的核心问题及解决方法

一、为什么要进行网络隔离&#xff1f; 随着互联网技术的发展和推进&#xff0c;人们对于网络使用的场景也越来越多元化&#xff0c;而网络黑客入侵、病毒攻击、网络泄密等安全事件的不断发生&#xff0c;也让人们认识到网络安全的重要性。企业、社会、国家机构在日常经营管理…

基于Pytorch框架的深度学习U2Net网络精细天空分割系统源码

第一步&#xff1a;准备数据 头发分割数据&#xff0c;总共有10276张图片&#xff0c;里面的像素值为0和1&#xff0c;所以看起来全部是黑的&#xff0c;不影响使用 第二步&#xff1a;搭建模型 级联模式 通常多个类似U-Net按顺序堆叠&#xff0c;以建立级联模型&#xff0c…

STM32(十二):DMA直接存储器存取

DMA&#xff08;Direct Memory Access&#xff09;直接存储器存取 DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输&#xff0c;无须CPU干预&#xff0c;节省了CPU的资源。&#xff08;运行内存SRAM、程序存储器Flash、寄存器&#xff09; 12个独立可配置的通道&…

【stata】自写命令分享twfe_stgdid,一键完成staggered-DID

1. 命令简介 仿照CSDID命令一键出实证结果、出图&#xff0c;我写了一个twfe_stgdid命令。基于双向固定效应模型&#xff08;TWFE&#xff09;一键式完成staggered-DID分析。TWFE估计did estimator时难以避免负权重带来的问题&#xff08;异质性处理效应&#xff09;。所以&am…

C++11新特性——右值引用与移动语义

左值引用和右值引用 在C中&#xff0c;左值是一个表示数据的表达式&#xff0c;我们可以获取它的地址&#xff0c;一般可以对它赋值&#xff0c;通常可以出现在左边或右边&#xff0c;左值引用就是对左值的引用&#xff0c;相当于给左值起了一个别名。 例子&#xff1a; int …

macOS安装Java和Maven

安装Java Java Downloads | Oracle 官网下载默认说最新的Java22版本&#xff0c;注意这里我们要下载的是Java8&#xff0c;对应的JDK1.8 需要登陆Oracle&#xff0c;没有账号的可以百度下。账号:908344069qq.com 密码:Java_2024 Java8 jdk1.8配置环境变量 open -e ~/.bash_p…

Autosar--Can收发器通俗讲解

Autosar网络管理的休眠唤醒功能,Can收发器起到比较大的作用,充当唤醒源以及最终执行网络休眠。 Autosar--Can收发器通俗讲解 唤醒/休眠请求 进入normol ComM_EcuM_WakeUpIndication 有唤醒源事件 CanSM_RequestComMode 有通信请求 CanSM_NetworkStatemachine() 更新CANS…

【C++】list(下)

个人主页~ list&#xff08;上&#xff09;~ list 四、模拟实现1、list.h&#xff08;1&#xff09;关于整个list的搭建①节点②迭代器③接口 &#xff08;2&#xff09;自定义类型实例化 2、test.cpp&#xff08;1&#xff09;test1&#xff08;2&#xff09;test2 五、额外小…

大模型入门 ch02:数据集准备

本文是github上的大模型教程LLMs-from-scratch的学习笔记&#xff0c;教程地址&#xff1a;教程链接 Chapter 2&#xff1a; Working with Text 这一章节包括了数据的准备和采样阶段。 1. Tokenizer 大模型通过将token转变为embedding&#xff08;词嵌入&#xff09;运作。 首…

【机器学习】高斯网络的基本概念和应用领域以及在python中的实例

引言 高斯网络&#xff08;Gaussian Network&#xff09;通常指的是一个概率图模型&#xff0c;其中所有的随机变量&#xff08;或节点&#xff09;都遵循高斯分布 文章目录 引言一、高斯网络&#xff08;Gaussian Network&#xff09;1.1 高斯过程&#xff08;Gaussian Proces…