日志搬家:http://www.loogn.net/blog/Article.aspx?id=21

关于日志记录,如果你不想随用随写,又不想用log4net的话,也许你可以了解一下这个!

我也是个很懒的人,程序上的东西,只要别人写好了,而且自己用着爽,绝不做重复的coding。这个组件的起源是因为感觉log4net太强大太复杂(对我来说真是这样),当我想用log4net的时候,看到配置我都吓尿n次了,而这个时候心中又突发奇想,用HTML来做日志的表现!理由有二,一是HTML和CSS大家都会,二是可以实现很好的可读可视性。

一、配置文件说明

<?xml version="1.0" encoding="utf-8" ?>
<LoggerConfig>
  <style>
    .fatal{
    background-color:red
    }
    .error{
    background-color:purple;
    }
    .warn{
    background-color:yellow;
    }
    .info{
    background-color:green;
    }
    .debug{
    background-color:gray;
    }

    .myinfo{
    font-size:24px;
    }
  </style>

  <tpls>
    <tpl name="fatal">
      <![CDATA[
        <p>
          <span class="fatal">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
    </tpl>
    <tpl name="error" >
      <![CDATA[
        <p>
          <span class="error">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
    </tpl>
    <tpl name="warn">
      <![CDATA[
        <p>
          <span class="warn">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
    </tpl>
    <tpl name="info">
      <![CDATA[
        <p>
          <span class="info">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
    </tpl>
    <tpl name="debug">
      <![CDATA[
        <p>
          <span class="debug">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
    </tpl>
  </tpls>

  <logs>
    <log name="default" path="D:\abc" types="all" dateFmt="yyyy-MM-dd HH:mm:ss">
      <tpl name="info">
        <![CDATA[
        <p>
          <span class="info myinfo">{type}</span>:{message}<br/>
          {date}
        </p>
      ]]>
      </tpl>
    </log>

    <log name="log2" path="D:\abc\a.html" types="fatal,error,warn,info,debug">
    </log>
  </logs>
</LoggerConfig>

LoggerConfig.xml

虽然上面的配置也不短,洒洒洋洋80大行,但它真的只有3个(或者说2个半)很简单的结点组成。

1、style结点,这个不说了,和html页面里style结点是一个样的,用于定义下面模板tpl里的样式。

2、tpls结点,这里定义的是日志类型的默认模板,模板内容大家都懂,就是HTML标签,其中有三个占位符{type}、{message}、{date},日志类型和{type}是指一类东西,分别是fatal,error,warn,info,debug五个类型,这一点是参考log4net,那里它叫日志级别。

3、logs结点,里面每个子结点即log结点都定义一个logger对象的属性和行为。

先看log结点的属性:

1)name为唯一表识,用来得到唯一logger对象(内部有缓存机制,随用随调,无须担心),name="default"表示默认logger

2)path为目录或具体文件,为目录时日志文件会根据日期生成, 如上“D:\abc” 会随着日期生成多个这个命名的文件(D:\abc\yyyy\MM\dd.html),当为具体文件时,应该是.html或.htm的文件,日志便会一直追加这一个文件。

3)types就是上面说过的5个类型,为空表示什么都不记录,多个type时用英文逗号隔开,如只记录致命错误和警告,就是types="fatal,warn",如果要全部记录,可用types="all"来简单表示types="fatal,error,warn,info,debug"。

4)dateFmt这个是模板里{date}的格式,默认是"yyyy-MM-dd HH:mm:ss",记录日志时将做为DateTime.ToString()的参数调用。

log结点的子结点:

和上面tpls的子结点一样,都是定义模板用的,上面是默认的,这里自然是特殊、可选的了,大家应该能想到这里的定义会覆盖默认的,而其实上也的确如此~_~!因为是重复的内容,所以上面才说配置文件一共就2个半结点组成。

二、调用API

把组件dll引入项目后,要在App.config和web.config里设置Logger配置文件的路径,如:

  <appSettings>
    <add key="loggerConfig" value="LoggerConfig.xml"/>
  </appSettings>

1、得到Logger对象

            //得到默认logger,即name="default"的那个
            var logger = Logger.GetInstance();
            //得到name="log2"的对象
            var log2 = Logger.GetInstance("log2");

2、简单记录日志

            logger.Debug("debugdebugdebug");
            logger.Info("infoinfoinfoinfoinfoinfo");

3、过虑记录日志,由于日志的内容很可能是动态的,所以组件提供的所有记录日志的方法都可传入一个委托来过虑掉那些自己不关心的内容

            //这个不会记录,开始为数字的被过滤掉了
            logger.Error("2323ErrorErrorErrorError", (s) =>Regex.IsMatch(s,@"^\d+"));
            //这个会记录,日志的内容在于10,不会被过滤
            logger.Fatal();

4、HTML展示,开始一直都说用HTML表示,效果是什么样呢?(此处的不美,不表示不支持优美的布局,程序员的界面,你们懂的!)

    以此献给那些喜欢简单编程的程序员们!下载

以HTML为表现的日志记录组件的更多相关文章

  1. log4net--不可多得的开源日志记录组件

    log4net--不可多得的开源日志记录组件 1 前奏 一直在用log4net日志工具,却没时间写个日志给大家分享一下这个工具,趁最近比较空些,好好分享一下这个工具. 2 说明 Log4net介绍就不 ...

  2. 【干货】.NET开发通用组件发布(四) 日志记录组件

    组件介绍和合作开发 http://www.cnblogs.com/MrHuo/p/MrHuoControls.html 日志记录组件功能介绍 通过基类Logger,实现了文本记录日志和数据库记录日志两 ...

  3. Elmah 日志记录组件

    http://www.cnblogs.com/jys509/p/4571298.html 简介 ELMAH(Error Logging Modules and Handlers)错误日志记录模块和处理 ...

  4. 日志记录组件[Log4net]详细介绍

    转载:http://www.cnblogs.com/liwei6797/archive/2007/04/27/729679.html 因为工作中有要用到Log记录,找到一篇不错的文章,就转了过来. 一 ...

  5. C#Log4net日志记录组件的使用

    一.Log4Net介绍 Log4net是基于.NET开发的一款非常著名的记录日志开源组件.它通过一套XML配置的日志引擎,将日志分不同的等级,分别是:FATAL . ERROR. WARN. INFO ...

  6. MVC使用 Elmah 日志记录组件

    在后台管理中,有一些操作是需要增加操作日志的,尤其是对一些比较敏感的金额类的操作,比如商城类的修改商品金额.删除商品.赠送金额等人工的操作.日志中记录着相关操作人的操作信息,这样,出了问题也容易排查. ...

  7. Log4Net异常日志记录在asp.net mvc3.0的应用

    前言 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介.本文主要是简单的介绍如何在Visual ...

  8. log4net日志记录

    这里是接着上一篇来优化的,上篇:ASP.NET MVC中错误日志信息记录 log4Net是用来记录日志的,可以将程序运行过程中的信息输出到一些地方(文件,数据库,EventLog等),日志就是程序的黑 ...

  9. Log4Net异常日志记录在asp.net mvc3.0的应用(转载)

    这篇博客写的很好:http://www.cnblogs.com/qianlifeng/archive/2011/04/22/2024856.html 前言 log4net是.Net下一个非常优秀的开源 ...

随机推荐

  1. 【Unity】改变向量的方向而不改变其大小

    最近在做一个打砖块游戏时遇到一个小问题,就是小球有可能会在左右两个边界之间做循环往返运动而导致游戏无法继续进行下去,于是我打算让小球在垂直撞向边界时改变一下方向,但是速度不变,尝试了一些方法但是没有达 ...

  2. QT5.5.0版本添加icon图标步骤

    1.制作icon图标文件 可以进入这个网站在线制作:http://www.ico.la/ 2.创建资源文件:qrc文件 接着 添加2两项,先点击prefix,然后添加文件--->图标路径 3.可 ...

  3. 解决Qt在openSUSE上编译出现“cannot find -lGL”错误

    在openSUSE上编译QT5.4程序出现“cannot find -lGL”,就连example都无法通过编译.QT是在官网下的最新的安装包. 大体意思是,缺少qt运行时所需要的openGL库.决绝 ...

  4. java设计模式之抽象工厂模式

    上一篇文章(http://www.cnblogs.com/liaoweipeng/p/5768197.html)讲了简单工厂模式,但是简单工厂模式存在一定的问题,如果想要拓展程序,必须对工厂类进行修改 ...

  5. 32-bit ALU [Verilog]

    Based on MIPS Instruction Structure Main Module module Alu( input [31:0] a, // operand 1 input [31:0 ...

  6. Caffe fine-tuning 微调网络

    转载请注明出处,楼燚(yì)航的blog,http://www.cnblogs.com/louyihang-loves-baiyan/ 目前呢,caffe,theano,torch是当下比较流行的De ...

  7. UVALive 5058 Counting BST --组合数

    题意:排序二叉树按照数插入的顺序不同会出现不同的结构,现在要在1~m选n个数,使按顺序插入形成的结构与给出的结构相同,有多少种选法. 解法:先将给出的结构插入,构造出一棵排序二叉树,再dfs统计,首先 ...

  8. 以最简单的登录为例,诠释JS面向对象的简单实例

    JavaScript,是前端开发人员必须会的一门技术,从JS演变出来的有很多框架,先说说几个热门的框架吧: JQuery:这个技术必须会,如果不会,那一定要会查api,知道怎么写,要看得懂英文文档,这 ...

  9. POJ2157Maze[DFS !]

    Maze Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 3818   Accepted: 1208 Description ...

  10. java io (一)

    对于文件内容的操作主要分为两大类 分别是:字符流 字节流 其中,字符流有两个抽象类:Writer   Reader 其对应子类FileWriter和FileReader可实现文件的读写操作 Buffe ...