关联配置文件的方式总结 

以控制台应用程序为例,在.net mvc项目中默认的配置位置为Web.config,其他的配置都一样

1.配置在AppConfig中

  在控制台应用程序中,如果我们把Log4net的配置放在App.config(App.config和Web.config是默认的位置)下,配置文件如下

<?xml version="1.0" encoding="utf-8"?>
<configuration>
<!--申明一个名为"log4net"的自定义配置节-->
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<!--Log4net 开始-->
<log4net>
<!--以下示例显示如何配置ColoredConsoleAppender 以将消息记录到控制台。默认情况下,消息被发送到控制台标准输出流。此示例显示如何突出显示错误消息-->
<appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender">
<mapping>
<level value="ERROR" />
<foreColor value="White" />
<backColor value="Red, HighIntensity" />
</mapping>
<mapping>
<level value="DEBUG" />
<backColor value="Green" />
</mapping>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<!-- 设置根类别,添加appender并设置默认级别 -->
<root>
<level value="ALL"/>
<appender-ref ref="ColoredConsoleAppender" />
</root>
</log4net>
<!--Log4net 结束-->
</configuration>

我们可以有两种方法来关联配置文件,选择一种:

方式一:在  AssemblyInfo.cs 文件中添加关联代码

方式二:在命名空间上部添加关联代码

  关联的代码为: [assembly: log4net.Config.XmlConfigurator(Watch = true)]

方式三:在程序入口使用代码关联,Console应用程序直接在Main函数第一行加上一行代码: log4net.Config.XmlConfigurator.Configure();

2.把配置文件放在Log4net.config

  我么也可以在项目中新建一个Log4net.config文件,其内容和App.config中一样,包含ConfigSections和log4net两个节点,在方式一/二中,和上边的步骤一样,只需要我们把关联的代码改成: [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config")] 即可。

  在方式三中,因为配置不在默认位置,所以我们要指定配置文件的信息,Console应用程序直接在Main函数第一行加上一行代码: log4net.Config.XmlConfigurator.Configure(fileInfo);,fileInfo为配置文件信息,详见下边栗子。

3.一个栗子

配置文件采用的上边的,保存在Log4net.Config文件中,关联配置的方式采用第三种,直接上代码:

 class Program
{
static void Main(string[] args)
{
//关联配置
System.IO.FileInfo fileInfo = new System.IO.FileInfo("Log4Net.config");//获取配置文件
//如果配置文件在App.config或者Web.config,不用查找配置文件,直接使用log4net.Config.XmlConfigurator.Configure()即可;
log4net.Config.XmlConfigurator.Configure(fileInfo);
Console.WriteLine("开始记录");
//获取一个ILog的实例
//myLogger为配置文件logger的name,如果没有logger节点,有root节点,代码中的"myLogger"可以为任意字符串,获取的都是默认的logger对象
ILog log = LogManager.GetLogger("myLogger");
log.Error("测试1", new Exception("这是一个Error"));
log.Warn("测试2", new Exception("这是一个Warn"));
log.Info("测试3", new Exception("这是一个Info"));
log.Debug("测试4", new Exception("这是一个Debug"));
log.Fatal("测试5", new Exception("这是一个Fatal"));
Console.ReadKey();
}
}

运行结果如下:

Log4net(二)-——关联配置文件的方式总结的更多相关文章

  1. Spring(二十):Spring AOP(四):基于配置文件的方式来配置 AOP

    基于配置文件的方式来配置 AOP 前边三个章节<Spring(十七):Spring AOP(一):简介>.<Spring(十八):Spring AOP(二):通知(前置.后置.返回. ...

  2. Springboot 打jar包分离lib,配置文件正确方式(二)

    Springboot 打jar包分离lib,配置文件正确方式(二) 背景 从<Springboot 打jar包分离lib,配置文件正确方式>中,可以达到把配置文件和依赖第三方的jar包分离 ...

  3. spring schedule定时任务(二):配置文件的方式

    接着上一篇,这里使用spring配置文件的方式生成spring定时任务. 1.相应的web.xml没有什么变化,因此便不再罗列.同样的,相应的java代码业务逻辑改动也不大,只是在原来的基础上去掉@C ...

  4. scala读取jar包外配置文件的方式

    在scala的开发过程中,经常会修改程序的参数,将这些参数放到配置文件中避免了重复编译,打包的过程 这里给出读取配置文件的三种方式 方式一: 这是最常见的读取配置文件方式 val postgprop ...

  5. 轻量级ORM框架 QX_Frame.Bantina(二、框架使用方式介绍)

    轻量级ORM框架QX_Frame.Bantina系列讲解(开源) 一.框架简介 http://www.cnblogs.com/qixiaoyizhan/p/7417467.html 二.框架使用方式介 ...

  6. Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据

    本来这篇文章在昨天晚上就能发布的,悲剧的是写了两三千字的文章居然没保存,结果我懵逼了.今天重新来写这篇文章.今天我们就一起来探讨下如何重写Ocelot配置文件的存储方式以及获取方式. 作者:依乐祝 原 ...

  7. MyBatis 实用篇(二)配置文件

    MyBatis 实用篇(二)配置文件 一.全局配置 全局配置:http://www.mybatis.org/mybatis-3/zh/configuration.html <?xml versi ...

  8. hibernate用配置文件的方式实现orm

    本文主要讲用配置文件的方式讲如何把一个对象和数据库中的表关联起来,其实用配置文件本质是和用注解的方式是一样的. 思路:1.写一个domain对象(如Person.java) 2.写这个domain对象 ...

  9. flask 设置配置文件的方式

    from flask import Flask from flask import current_app """ 配置参数设置与读取 """ ...

随机推荐

  1. org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document from class path resource [applicationContext.xml]; nested exception is java.io.FileNotFoundException: c

    //这个是 配置文件放错了地方 org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing ...

  2. CentOS 7 Install Adobe Flash Player

    From Officail Adobe Flash Site don't down (YUM )adobe-release-x86_64-1.0-1.noarch.rpm,but to downloa ...

  3. Appium学习笔记4_元素定位方法

    Appium之元素定位,如果对Android上如何使用工具获取页面元素有问题的,请转战到这:http://www.cnblogs.com/taoSir/p/4816382.html. 下面主要是针对自 ...

  4. 【Java集合的详细研究4】Java中如何遍历Map对象的4种方法

    方法一 通过Map.entrySet遍历key和value,在for-each循环中使用entries来遍历.推荐,尤其是容量大时 这是最常见的并且在大多数情况下也是最可取的遍历方式.在键值都需要时使 ...

  5. WorkStation 虚拟机迁移到 ESXi的后续处理.

    自己遇到了然后按照blog http://blog.sina.com.cn/s/blog_79a8b8e10102w8bm.html 解决 特此记录一下. 将Workstation的vmdk文件导入到 ...

  6. cmd常用

    npm install -g npm              npm就自动为我们更新到最新版本 npm install -g cnpm --registry=https://registry.npm ...

  7. Java基础总结(一)

    1:程序执行是有顺序的,如果没有流程控制语句,执行顺序是从上到下, 2:对象没有引用指向他的时候,jvm虚拟机就会在合适的时候去清理内存垃圾 3:对象的引用就相当于方向盘,操作对象 4:java8大基 ...

  8. ceph 安装过程

    安装依赖: yum install -y yum-utils && yum-config-manager --add-repo https://dl.fedoraproject.org ...

  9. BZOJ1127 POI2008KUP(悬线法)

    首先显然地,如果某个格子的权值超过2k,其一定不在答案之中:如果在[k,2k]中,其自身就可以作为答案.那么现在我们只需要考虑所选权值都小于k的情况. 可以发现一个结论:若存在一个权值都小于k的矩阵其 ...

  10. Ouroboros Snake POJ - 1392(数位哈密顿回路)

    看hdu 2894的题意  两个题一样 旋转鼓的表面分成m块扇形,如图所示(m=8).图中阴影区表示用导电材料制成,空白区用绝缘材料制成,终端a.b和c是3(k=3)处接地或不是接地分别用二进制信号0 ...