点这里进入ABP系列文章总目录javascript
基于DDD的现代ASP.NET开发框架--ABP系列之八、ABP日志管理
html
ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称。java
ABP的官方网站:http://www.aspnetboilerplate.comgit
ABP在Github上的开源项目:https://github.com/aspnetboilerplategithub
本文由东莞-天道提供翻译web
ASP.NET Boilerplate使用Castle Windsor's logging facility日志记录工具,而且可使用不一样的日志类库,好比:Log4Net, NLog, Serilog... 等等。对于全部的日志类库,Castle提供了一个通用的接口来实现,咱们能够很方便的处理各类特殊的日志库,并且当业务须要的时候,很容易替换日志组件。数据库
译者注释:Castle是什么:Castle是针对.NET平台的一个开源项目,从数据访问框架ORM到IOC容器,再到WEB层的MVC框架、AOP,基本包括了整个开发过程当中的全部东西。ASP.NET Boilerplate的ioc容器就是经过Castle实现的。
Log4Net 是asp.net下面最流行的一个日志库组件, ASP.NET Boilerplate 模板也使用了Log4Net日志库组件,可是呢,咱们这里仅仅经过一行关键代码就实现Log4Net 的依赖注入(具体说明在下面的配置文件),因此,若是你想替换成本身的日志组件,也很容易。apache
无论你选择哪个日志库组件,经过代码来进行日志记录都是同样的。(这里吐槽, Castle's 通用 ILogger 接口实在太牛逼了)。api
下面进入正题:(译者注:下面的代码是abp框架的Castle.Core源码分析以及实现)浏览器
一、首先呢,咱们要先处理日志记录器对象logger, ASP.NET Boilerplate框架使用了dependency injection依赖注入技术,咱们能够很方便的使用依赖注入生成日志记录器对象logger。
接下来咱们看一下 ASP.NET Boilerplate是怎么实现日志记录功能的吧:
using Castle.Core.Logging; //1: 导入日志的命名空间,Castle.Core.Logging
public class TaskAppService : ITaskAppService { //2:经过依赖注入获取日志记录器对象。 这里先定义了一个ILogger类型的public属性Logger,这个对象就是咱们用来记录日志的对象。在建立了TaskAppService对象(就是咱们应用中定义的任务)之后,经过属性注入的方式来实现。 public ILogger Logger { get; set; } public TaskAppService() { //3: 若是没有日志记录器,将日志记录器返回一个空的实例,不写日志。这是依赖注入的最佳实现方式,
// 若是你不定义这个空的日志记录器,当咱们获取对象引用而且实例化的时候,就会产生异常。
// 这么作,保证了对象不为空。因此,换句话说,不设置日志记录器,就不记录日志,返回一个null的对象。
// NullLogger对象实际上什么都木有,空的。这么作,才能保证咱们定义的类在实例化时正常运做。 Logger = NullLogger.Instance; }
public void CreateTask(CreateTaskInput input) { //4: 写入日志 Logger.Info("Creating a new task with description: " + input.Description);
//TODO: save task to database...
} }
写入日志之后,咱们能够查看日志文件,就像下面的格式:
INFO 2014-07-13 13:40:23,360 [8 ] SimpleTaskSystem.Tasks.TaskAppService - Creating a new task with description:Remember to drink milk before sleeping!
ASP.NET Boilerplate框架提供了MVC Controllers、Web API Controllers和Application service classes的基类(本身定义的控制器和应用服务,都必需要继承ASP.NET Boilerplate的基类,换句话说,当你自定义的Web API controllers、mvc controllers,Application service classes都继承了ASP.NET Boilerplate框架对应的基类,你就能够直接使用日志记录器)。
public class HomeController : SimpleTaskSystemControllerBase { public ActionResult Index() { Logger.Debug("A sample log message..."); return View(); } }
说明:SimpleTaskSystemControllerBase这个基类控制器是咱们本身定义的基类控制器,他必须继承自 AbpController。
这样实现,日志记录器才能正常工做。固然了,你也能够实现本身的基类,这样的话你也能够不使用依赖注入了。
若是你在官网上经过ASP.NET Boilerplate templates 来生成了你的工程,Log4Net的全部配置都自动生成了。
默认的配置格式以下:
配置文件:log4net.config 通常都在项目的web目录下面。
<?xml version="1.0" encoding="utf-8" ?> <log4net> <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender" > <file value="Logs/Logs.txt" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <maxSizeRollBackups value="10" /> <maximumFileSize value="10000KB" /> <staticLogFileName value="true" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%-5level %date [%-5.5thread] %-40.40logger - %message%newline" /> </layout> </appender> <root> <appender-ref ref="RollingFileAppender" /> <level value="DEBUG" /> </root> <logger name="NHibernate"> <level value="WARN" /> </logger> </log4net>
Log4Net是一个很是强大和易用的日志库组件,你能够写各类日志,好比写到txt文件,写入到数据库等等。你能设置最小的日志等级,就像上面这个针对NHibernate的配置。不一样的记录器写不一样的日志,等等。
具体的用法你们能够参照:http://logging.apache.org/log4net/release/config-examples.html
最后,在工程的Global.asax 文件中,来定义Log4Net的配置文件:
public class MvcApplication : AbpWebApplication { protected override void Application_Start(object sender, EventArgs e) { IocManager.Instance.IocContainer.AddFacility<LoggingFacility>(f => f.UseLog4Net().WithConfig("log4net.config")); base.Application_Start(sender, e); } }
几行代码就调用了Log4Net这个日志记录组件,工程中的Log4Net库是在 nuget package包中的,你也能够换成其余日志组件库,可是代码不用作任何改变。由于,咱们的框架是经过依赖注入实现日志记录器的!
最后,更厉害的是,你还能够在客户端调用日志记录器。在客户端,ASP.NET Boilerplate框架有对应的 javascript 日志API,这意味着你能够记录下来浏览器的日志,实现代码以下:
abp.log.warn('a sample log message...');
附上:客户端javascript的api,这里要说明的是,你可使用console.log在客户端输出日志,可是这个API 不必定支持全部的浏览器,还有可能致使你的脚本出现异常,你可使用咱们的api,咱们的是安全的,你甚至能够重载或者扩展这些api。
abp.log.debug('...'); abp.log.info('...'); abp.log.warn('...'); abp.log.error('...'); abp.log.fatal('...');
但愿更多国内的架构师能关注到ABP这个项目,也许这其中有能帮助到您的地方,也许有您的参与,这个项目能够发展得更好。
欢迎加ABP架构设计交流QQ群:134710707