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

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

原理:先生成一个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的值是可以随便改

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

///

/// 写入错误日志 ///

/// 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一次了),好了就这么点东西了。

posted @ 2013-03-15 10:08 一抹、思乡泪 阅读(252) 评论(5) 编辑 收藏

评论列表

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

原理:先生成一个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的值是可以随便改

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

///

/// 写入错误日志 ///

/// 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一次了),好了就这么点东西了。

posted @ 2013-03-15 10:08 一抹、思乡泪 阅读(252) 评论(5) 编辑 收藏

评论列表


相关内容

  • 高级保安员职业资格全省统一鉴理论模拟卷2
  • A安全技术防范系统警情类别中的"其他事件"是指:旁路.撤布防.测试报告和 . (A)劫盗报警 (B)故障报警 (C)计划任务事件 (D)用户状态报告 正确答案:D A安全检查方法包括( ).现场观察.实地检测相结合的方法,记录检测结果,及时纠正发现的违章指挥和违规作业行为. (A ...

  • 用友U8+V12.1公共插件V7.6操作手册(业务协同平台)
  • U8V12.1公共插件V7.6业务协同平台 操作手册 + U8研发中心 2015年08月 目录 1 2 实施准备.............................................................................................. ...

  • 计算机网络安全与应用技术实训报告
  • <计算机网络安全与应用技术>实 训 报 告安徽水利水电职业技术学院ANHUI WATER CONSERVANCY TECHNICAL COLLEGE二〇一四年一月<计算机网络安全与应用-实训报告>安徽水利水电职业技术学院第 一 部 分概述本次实习每人独自完成实习报告,相关软件 ...

  • 2008产品技术手册
  • 汉邦高科产品技术手册 北京汉邦高科数字技术有限公司 2008年6 月 汉邦高科产品手册 目 录 1.公司简介 ................................................................. 2 1.1公司简介 ................... ...

  • 校园网络实施方案
  • 校园网络实施方案 一.论文概述: ··············································································································· 2 二.如何评价网络系统的整体安全性··· ...

  • 2014年自考软件开发工具资料笔记
  • 软件开发工具资料笔记 第1章 绪论 1.1 软件开发工具的由来 1.软件产品的(质量)(效率)(价格)已成为各方面关注的十分重要的问题.(多选题) 2.名词解释:软件开发工具 在高级程序设计语言的基础上,为提高软件的质量和效率,从规划.分析.设计.测试.成文和管理各方面,对软件开发者提供各种不同程度 ...

  • 实验三网络安全扫描器
  • 实验三 网络安全扫描器 1.实验背景 X-Scan采用多线程方式对指定IP地址段(或单机)进行安全漏洞检测,支持插件功能.扫描内容包括:远程服务类型.操作系统类型及版本,各种弱口令漏洞.后门.应用服务漏洞.网络设备漏洞.拒绝服务漏洞等20多个大类.对于多数已知漏洞,给出了相应的漏洞描述.解决方案及详 ...

  • 轻松搭建网络流媒体服务器
  • 作者:王志军  [2004-04-30] 现在,越来越多的朋友用上了宽带,如果仅仅只是将宽带用来下载软件.观看电影,那未免太浪费了.假如你的机器性能还不错的话,是否设想过将它架设为一台流媒体服务器.这样就可以与亲朋好友共享美妙的音乐或最新的电影,那种网络DJ的感受可真是无与伦比呀. 就现在的主流计算 ...

  • 网站智能管理系统
  • 网站智能管理系统 1.1系统概述 智能管理是一种把后端系统中的数据(工作流系统.业务系统.OA 系统等) ,外部系 统中的数据(活动.邮件等),采编发的内容数据灵活展示于前端网络平台的工具.能够协助组织和个人,借助信息技术,实现内容的创建.储存.分享.应用.更新,并在企业.个人.组织.业务.战略等诸 ...