C# Winform 自定义异常处理方法


一个简单的统一异常处理方法。系统底层出现异常,写入记录文件,系统顶层捕获底层异常,显示提示信息。

   /// <summary>
    /// 自定义异常类
    /// </summary>
    public static class ExceptionExtension

    {
        /// <summary>
        /// 用户自定义错误消息
        /// </summary>
        public static string ErrorMessage { get; set; }

        /// <summary>
        /// 写入异常日志
        /// </summary>
        /// <param name="ex"></param>
        /// <param name="Message">用户自定义错误消息</param>
        public static void WriterExceptionLog(Exception ex, string Message = "")
        {
            string filePath = Environment.CurrentDirectory.Replace(@"\bin\Debug", "") + @"\ErrorLog";
            if (!System.IO.Directory.Exists(filePath))
            {
                System.IO.Directory.CreateDirectory(filePath);
            }
            string fileName = filePath + @"\ErrorLog.txt";

            StringBuilder errorInfo = new StringBuilder();
            errorInfo.Append($"*******异常发生时间:{DateTime.Now}*******\n");
            errorInfo.AppendFormat(" 异常类型: {0} \n", ex.HResult);
            //msg.AppendFormat(" 导致当前异常的 Exception 实例: {0} \n", ex.InnerException);
            errorInfo.AppendFormat(" 导致异常的应用程序或对象的名称: {0} \n", ex.Source);
            errorInfo.AppendFormat(" 引发异常的方法: {0} \n", ex.TargetSite);
            errorInfo.AppendFormat(" 异常堆栈信息: {0} \n", ex.StackTrace);
            errorInfo.AppendFormat(" 异常消息: {0} \n", ex.Message);
            errorInfo.AppendFormat(" 系统信息: {0} \n", Message);
            ErrorMessage += Message;
            try
            {
                if (File.Exists(fileName))
                {
                    using (StreamWriter tw = File.AppendText(fileName))
                    {
                        tw.WriteLine(errorInfo.ToString());
                    }
                }
                else
                {
                    TextWriter tw = new StreamWriter(fileName);
                    tw.WriteLine(errorInfo.ToString());
                    tw.Flush();//将缓冲区的数据强制输出,清空缓冲区
                    tw.Close();//关闭数据流
                    tw = null;
                }
            }
            catch (Exception) { Console.ReadKey(); }
        }
    }
}

比较简单,该类仅定义了一个属性和一个方法。具体使用如下:系统底层(例如数据访问层或业务逻辑层)发现异常时, 记录异常信息,将异常上抛。例如:
    //后台处理
    try
    {
        //有可能发生异常操作
    }
    catch (Exception ex)
    {
        string strSlq = "";
        ExceptionExtension.WriterExceptionLog(ex, "在查询记录时发生异常。SQL语句为:" + strSlq);
        throw;//向上抛出异常
    }
    finally
    {
        //清理
    }

用户交互层,捕获底层异常,显示提示信息。例如:

   //用户界面
    try
    {
        //调用底层有可能发生异常操作
    }
    catch (Exception)
    {
        //MessageBox.Show(ExceptionExtension.ErrorMessage, "系统异常错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
    finally
    {
        //清理
    }

完成。

引用来源:https://www.cnblogs.com/LiYunQi/p/15751493.html

版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
管理员
上一篇:初识MASA Blazor
下一篇:C# 执行Javascript脚本
评论列表

发表评论

评论内容
昵称:
关联文章

C# Winform 定义异常处理方法
C# 配置文件增加定义节点
窗体定义权限操作按钮
YES-Win Winform开发框架 定义查询方法并在表格中展示
Excel定义格式千分符
.NET Core 定义中间件 Middleware
C#常见异常列表
使用.NET 6开发TodoList应用(8)——实现全局异常处理
winform定义控件(UserControl)加载慢的研究
定义表格操作按钮 GridControlEmbeddedNavigator
C#图片处理
GZUpdate自动升级之定义更新补丁程序
窗体GridView布局定义
Vue.js中如何限制Props只接受特定数组值:定义验证方法解析
C#错误异常日志记录到文件
自己创造一个格式,定义文件后缀名
WPF开发随笔收录-定义图标控件
ABP VNext框架中Winform终端的开发和客户端授权信息的处理
EF并发处理,防止并发修改数据
AS.NET Core定义类中全局访问HttpContext

联系我们
联系电话:15090125178(微信同号)
电子邮箱:garson_zhang@163.com
站长微信二维码
微信二维码