在.NET Core程序中设置全局异常处理

以前我们想设置全局异常处理只需要这样的代码:

1 AppDomain currentDomain = AppDomain.CurrentDomain;
2 currentDomain.UnhandledException += new UnhandledExceptionEventHandler(MyExceptionHandler);

但是在.NET Core中并没有AppDomain的相关实现,至少在.NET Core最新的发布版本里没有。

以前我和网友@SillyPGM的讨论,然后我们查看了部分Clr的源代码后发现,在AppContext类里有UnhandledException的实现代码,但是结果又一次失望,最新的代码是14天前提交的。

带着沮丧我去翻看了社区提交的ISSUES 如下:  https://github.com/dotnet/corefx/issues/6398

最后发现了由SamuelEnglard提交的有关AppDomain的解决方案,经过SillyPGM的验证,证明了这个第三方库的有效性。

这个库的原理很简单就是通过反射将AppDomain类的事件字段,然后通过构建ExpressionTree生成Delegate。

原理很简单,但是包含了智慧,以后有什么搞不定的,看看源代码,如果有实现就直接照着他的方案来吧。

大家一起观摩:https://github.com/SamuelEnglard/System.AppDomain  上面有单元测试

当然也不需要把源代码Down下来自己搞,作者给咱们提供了Nuget:  https://www.nuget.org/packages/System.AppDomain/2.0.11

GitHub:https://github.com/maxzhang1985/YOYOFx  如果觉还可以请Star下, 欢迎一起交流。

.NET Core 和 YOYOFx 的交流群: 214741894 

如果你觉得本文对你有帮助,请点击“推荐”,谢谢。

时间: 2024-10-25 05:01:50

在.NET Core程序中设置全局异常处理的相关文章

C#程序中设置全局代理(Global Proxy)

1. HttpWebRequest类的Proxy属性,只要设置了该属性就能够使用代理了,如下: 1 //设置代理 2 WebProxy WP = new WebProxy("41.76.44.76", 3128); 3 ICredentials jxCredt = new NetworkCredential("proxy_username", "proxy_password"); 4 WP.Credentials = jxCredt; 5 6 H

[Z] C#程序中设置全局代理(Global Proxy)

https://www.cnblogs.com/Javi/p/7274268.html 1. HttpWebRequest类的Proxy属性,只要设置了该属性就能够使用代理了,如下: 1             //设置代理 2         WebProxy WP = new WebProxy("41.76.44.76", 3128); 3             ICredentials jxCredt = new NetworkCredential("proxy_us

Qt应用程序中设置字体

Qt应用程序中设置字体 应用程序中经常需要设置字体,例如office软件或者是其他的编辑器软件等等.这里主要涉及到如下几个概念:字体,字号以及风格(例如:粗体,斜体,下划线等等).Qt里面也有对应的类.接下来我们主要对这几个类进行详细的说明,最后举例说明它们的应用. 1.Qt中相关的类:QFontDatabase.QFont.QFontInfo和QFontMetrics.QFontMetricsF: (1)QFontDatabase QFontDatabase类提供了底层窗口系统所提供的系统可用

VS2013中设置全局属性

为了更好的体现程序与库的独立性,vc++2013 中库路径设置不再采用全局设置,就是说在每个工程中都可以有自己独立的库路径设置,当然你如果不设置,那默认就是vs2013自己的库路径.但是如果你需要用到第三方库,应该怎么设置呢? 很简单,新的设置点不再是工具--选项--工程和解决方案-VC++ 目录(已弃用):而是工程--属性--配置属性--VC++ 目录 (这样是属于局部设置). 也可以在项目--xxx属性--VC++ 目录中来设定 2.若常常使用VS来创建工程,那么每创建一个工程都要如上操作一

.NET Core程序中使用User Secrets存储敏感数据

前言 在开发中经常会用到一些敏感数据比如AppSecret或数据库连接字符串无论是硬编码还是写在配置文件中最终都要push到svn或git上.对于开源项目这些敏感数据就无隐私可言了对于私有项目一旦源代码管理服务器被黑这些敏感数据也将暴露无遗.所以最佳实践就是不要将敏感数据写到源代码中. 以往我们常常将数据库连接字符串写在web.config中.NET Core中写在appsettings.json中开发环境下如果一个开发者修改了连接字符串为了不影响其他开发者每次提交代码的时候就应该忽略该配置文件

在Winform程序中设置管理员权限及为用户组添加写入权限

在我们一些Winform程序中,往往需要具有一些特殊的权限才能操作系统文件,我们可以设置运行程序具有管理员权限或者设置运行程序的目录具有写入的权限,如果是在操作系统里面,我们可以设置运行程序以管理员身份运行,或者设置Users用户组在运行目录中具有写入权限都可以解决问题,不过如果我们想通过C#代码进行自动的处理,那么应该如何实现呢? 1.系统设置管理员权限或者目录写入权限 如果我们需要让程序以管理员身份运行,那么可以通过设置快捷方式的属性或者应用程序的属性为[以管理员身份运行此程序]即可实现,如

python 程序中设置环境变量

python 中调用系统命令有三种方法: 1.os.system('command') ,这个方法是直接调用标准C的system() 函数,仅仅在一个子终端运行系统命令,而不能获取命令执行后的返回信息. 2.os.popen('command'),该方法不但执行命令还返回执行后的信息对象,是通过一个管道文件将结果返回,例如可以设置一个变量,返回结果. 1 cha = os.popen('ls /').readlines 3.模块subprocess,实际使用过程中发现,假设要在代码当前进程中设置

WEB 项目中的全局异常处理

在web 项目中,遇到异常一般有两种处理方式:try.....catch....:throw 通常情况下我们用try.....catch.... 对异常进行捕捉处理,可是在实际项目中随时的进行异常捕捉,会造成代码重复和繁杂,我们希望代码中只有业务相关的操作,所有的异常我们单独设立一个类来处理它. 首先,我们在可能发生异常的方法,全部throw出来,即dao抛给service.service给controller.controller抛给前端控制器: 然后由前端控制器调用 全局异常处理器  对异常

(转)在Winform程序中设置管理员权限及为用户组添加写入权限

本文转载自:http://www.cnblogs.com/wuhuacong/p/5645172.html 在我们一些Winform程序中,往往需要具有一些特殊的权限才能操作系统文件,我们可以设置运行程序具有管理员权限或者设置运行程序的目录具有写入的权限,如果是在操作系统里面,我们可以设置运行程序以管理员身份运行,或者设置Users用户组在运行目录中具有写入权限都可以解决问题,不过如果我们想通过C#代码进行自动的处理,那么应该如何实现呢? 1.系统设置管理员权限或者目录写入权限 如果我们需要让程