利用反射写一个简单的错误日志插件

本文介绍了一种使用反射技术动态加载错误日志处理插件的方法。通过配置文件指定DLL路径、类名及方法名,可以灵活地替换错误消息的处理方式,如写入文件或保存至数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

反射用好了真的强大,下面就简单示例一下利用反射写各错误日志的插件。

原理:先生成一个dll文件,这个文件是用来将错误消息写入到文件,或者是将消息保存到数据库中,反正这个dll(插件)就是用来处理错误消息的,

错误消息从哪里来呢?当然是主程序了,这都用问,o(︶︿︶)o ,我又一次被BS了,:-),那么我们怎么用这个外部的dll文件呢,当然是用反射了,

我们把这个dll文件的路径、dll里的类名、方法名这些放在一个配置文件里,然后通过反射取到他们,再调用他,说白了就是动态加载。这描述能力....

  自己先寒一个 — —!

代码:先写个写入txt文件的类,然后生成dll文件,代码很简单,没什么好说的,当然你可以写各保存到数据库的类,这里我图各省事,应为这个不是重点。

复制代码
namespace Model
{
    public class Error
    {
        public void ErrorWriter(string mess)
        {
            using (System.IO.StreamWriter writer=new System.IO.StreamWriter("ErrorWriter.txt",true))
            {
                writer.WriteLine(mess);
            }
        }
    }
}
复制代码

然后下面我们就来写配置文件,当然这个也很简单,在用ADO.Net的时候天天基本上就和这玩意打交到,用appSettings是应为value的值是可以随便改

复制代码
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <appSettings>
    <!--dll文件路径-->
    <add key="plugPath" value="Model.dll"/>
    <!--类名-->
    <add key="className" value="Model.Error"/>
    <!--处理错误消息的方法-->
    <add key="methName" value="ErrorWriter"/>
  </appSettings>
</configuration>
复制代码

下面就是利用反射来取这些路径、类、方法,我们不用关心value里的值,不过您别手贱去改key的值,用不了那就不是我的事了哈 o(∩_∩)o 

复制代码
 /// <summary>
 /// 写入错误日志
 /// </summary>
 /// <param name="mess"></param>
 static void WriteMessage(string mess)
 {
    string path= ConfigurationManager.AppSettings["plugPath"];
    Assembly ass = Assembly.LoadFile(Path.GetFullPath(path));//根据路径加载程序集
    string className = ConfigurationManager.AppSettings["className"];
    Type type = ass.GetType(className);//获取到dll中类名
    string methName = ConfigurationManager.AppSettings["methName"];
    MethodInfo meth = type.GetMethod(methName);//获取到处理消息的方法
    if (meth!=null)
    {
        //创建Error类的实例,调用Error类里的ErrorWriter方法, new object[]是参数集合
        meth.Invoke(Activator.CreateInstance(type), new object[] { mess });
    }
 }
复制代码

怎么调用WriteMessage方法就不用说了吧(又被BS一次了),好了就这么点东西了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值