1. log4net:保存日志到数据库
  2. 自定义参数
    1. 新建一个类,继承于PatternLayoutConverter

      public class CustomerPatternConverter : PatternLayoutConverter
      {
      protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent)
      {
      if (Option != null)
      {
      // Write the value for the specified key
      WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
      }
      else
      {
      // Write all the key value pairs
      WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
      }
      } /// <summary>
      /// 通过反射获取传入的日志对象的某个属性的值
      /// </summary>
      /// <param name="property"></param>
      /// <returns></returns>
      private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
      {
      object propertyValue = string.Empty; PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
      if (propertyInfo != null)
      propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null); return propertyValue;
      }
      }
    2. 创建自定义Layout
      public class MyLayout:log4net.Layout.PatternLayout
      {
      public MyLayout()
      {
      this.AddConverter("Customer",typeof(CustomerPatternConverter));
      }
      }
    3. 创建一个类,用来保存需要保存到数据库中的数据
      public class LogContent
      { public string CustomerCol { get; set; } public string Test { get; set; }
      }
    4. 修改数据库的表结构
      alter table dbo.[log] add customerCol nvarchar(max)
      alter table dbo.[log] add Test nvarchar(max)
    5. 修改配置文档,在文档中添加如下parameter
      <parameter>
      <parameterName value="@customerCol"/>
      <dbtype value="String"/>
      <size value=""/>
      <Layout type="Tospur.Test.Log4net.MyLayout">
      <param name="ConversionPattern" value="%Customer{CustomerCol}"></param>
      </Layout>
      </parameter>
      <parameter>
      <parameterName value="@Test"/>
      <dbtype value="String"/>
      <size value=""/>
      <Layout type="Tospur.Test.Log4net.MyLayout">
      <param name="ConversionPattern" value="%Customer{Test}"></param>
      </Layout>
      </parameter>
    6. 修改配置文件中的sql语
      <commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[customerCol],[Test]) 
      VALUES (@log_date, @thread, @log_level, @logger, @message,@customerCol,@Test)" />
    7. 运行代码
      static void Main(string[] args)
      {
      log4net.ILog log = log4net.LogManager.GetLogger("logdb");
      log.Info(new LogContent { CustomerCol="", Test="TEst" });
      Console.ReadKey();
      }
  3. 运行程序,查看结果

http://www.cnblogs.com/MQNH/articles/5603326.html

log4net:保存自定义参数到数据库的更多相关文章

  1. log4net保存到数据库系列三、代码中xml配置log4net

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志一.WebConfig中配置log4net 一.WebConfig中配置log4ne ...

  2. Log4net 自定义字段到数据库

    今天要求做个log4net自定义字段到数据库,在网上找了好多例子,都运行不成功.最后找了个国外的,很简单的就解决了. log4net它已经定义的字段有 <commandText value=&q ...

  3. log4net保存到数据库系列五、新增数据库字段

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志一.WebConfig中配置log4net 一.WebConfig中配置log4ne ...

  4. log4net保存到数据库系列四、完整代码配置log4net

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志一.WebConfig中配置log4net 一.WebConfig中配置log4ne ...

  5. log4net保存到数据库系列二:独立配置文件中配置log4net

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志一.WebConfig中配置log4net 一.WebConfig中配置log4ne ...

  6. log4net保存到数据库系列一:WebConfig中配置log4net

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志 一.WebConfig中配置log4net 二.独立配置文件中配置log4net ...

  7. log4net 写数据到sql数据库

    最近需要把用户的一些行为添加到数据库中,所以想到了用log4net ,如果有别的好的方案,大家可以给我指正. 先看一下配置文件 我这个是控制台文件 app.config <layout type ...

  8. Apache DolphinScheduler 使用文档(7/8):系统参数及自定义参数

    本文章经授权转载,原文链接: https://blog.csdn.net/MiaoSO/article/details/104770720 目录 7. 参数 7.1 系统参数 7.2 时间自定义参数 ...

  9. loadrunner怎么将变量保存到参数中

    用这个lr_save_string 函数 char *b = "很简单";lr_save_string(b,"b"); lr_output_message(&q ...

随机推荐

  1. PHP判断变量是否为整型

    1.使用is_int() 2.使用is_numeric() 两个函数的区别,当变量为'1'时, is_int()的返回值为false, is_numeric()的返回值为true 当变量为1时, 两个 ...

  2. Windows Store App 旋转中心

    旋转中心的位置可以通过设置CenterOfRotationX.CenterOfRotationY和CenterOfRotationZ属性来指定.CenterOfRotationX和CenterOfRo ...

  3. 6、android 网络编程

    1.基于socket的用法 服务器端: 先启动一个服务器端的socket     ServerSocket svr = new ServerSocket(8989); 开始侦听请求 Socket s  ...

  4. Android常见控件— — —Button

    <?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android=&qu ...

  5. Android使用SharedPreference存储数据

    SharedPreference存储数据和文件存储更加方便的一点是可以按照一定的数据类型进行存储,同时取数据时也能够获取到相应的数据类型.它是按照map的方式来存储和读取数据的. MainActivi ...

  6. js 上传文件预览

    1. FILE API html5提供了FIle和FileReader两个方法,可以读取文件信息并读取文件. 2. example <html> <body> <div ...

  7. Simple Maven Project

    为pom.xml添加组织,法律和开发人员信息 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=&qu ...

  8. SVN小贴士

    我辛辛苦苦写的到哪里了? SVN小贴士SVN服务器上的代码项目组公用,你的每一个提交都会体现给项目组每个人,所以提交要慎重,要注意避免代码冲突,使用SVN小贴士: 1.提前宣布开发计划,保持项目组成员 ...

  9. 【Avalon】factory

    (function(global, factory) { if (typeof module === "object" && typeof module.expor ...

  10. fastqc, Per Base Sequence Content

    Per Base Sequence Content对所有reads的每一个位置,统计ATCG四种碱基(正常情况)的分布: 横轴为位置,纵轴为百分比. 正常情况下四种碱基的出现频率应该是接近的,而且没有 ...