参考页面:

http://www.yuanjiaocheng.net/entity/entitytypes.html

http://www.yuanjiaocheng.net/entity/entity-relations.html

http://www.yuanjiaocheng.net/entity/entity-lifecycle.html

http://www.yuanjiaocheng.net/entity/code-first.html

http://www.yuanjiaocheng.net/CSharp/csharprumenshili.html

上一篇, 都是从别人那里拷过来的, 主要是介绍规则和说明的. 这一篇, 才是重点, 讲实际使用.

首先介绍项目中最常用的配置文件方式.

一、log4net.config 文件方式

我习惯, 把log4net的配置, 放在一个单独的配置文件中, 而不是放在 app.config或者web.config文件中, 这样做, 虽然麻烦了一点, 但是好处就是泾渭分明, 清晰明了.

1. 首先要做的, 就是在 AssemblyInfo.cs 文件中, 加一句话

[assembly:log4net.Config.DOMConfigurator(Watch=true, ConfigFile="Log4net.config")]

2. 接下来, 有两种方法, 一种是在app.config/web.config文件中加两句话, 另一种是在程序中加一句话. 那么先看第一种吧.

2.1 web.config

<configSections>
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net configSource="log4net.config" />

与这无关的配置, 我都干掉了.  接下来, 可以看看我的 Log4net.config文件

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
  <root>
    <level value="ALL" />
    <appender-ref ref="ErrorLogFileAppender" />
    <appender-ref ref="TraceLogFileAppender" />
  </root>

  <!--跟踪日志输出-->
  <appender name="TraceLogFileAppender" type="log4net.Appender.RollingFileAppender">
    <file value="Logs\Trace\" />
    <appendToFile value="true" />
    <MaxSizeRollBackups value="20" />
    <RollingStyle value="Date" />
    <DatePattern value="yyyy-MM-dd'.txt'" />
    <StaticLogFileName value="false" />
    <layout type="log4net.Layout.PatternLayout,log4net">
      <header value="[BEGIN LOGGING AT %date]%newline" type="log4net.Util.PatternString" />
      <footer value="[END LOGGING AT %date]%newline%newline" type="log4net.Util.PatternString" />
      <ConversionPattern value="%d [%t] %-5p %c - %m%n" />
    </layout>
    <filter type="log4net.Filter.LevelRangeFilter,log4net">
      <levelMin value="DEBUG" />
      <levelMax value="INFO" />
    </filter>
  </appender>

  <!--错误日志输出-->
  <appender name="ErrorLogFileAppender" type="log4net.Appender.RollingFileAppender">
    <file value="Logs\Error\" />
    <MaxSizeRollBackups value="20" />
    <StaticLogFileName value="false" />
    <DatePattern value="yyyy-MM-dd'.txt'" />
    <RollingStyle value="Date" />
    <appendToFile value="true" />
    <layout type="log4net.Layout.PatternLayout,log4net">
      <header value="[BEGIN LOGGING AT %date]%newline" type="log4net.Util.PatternString" />
      <footer value="[END LOGGING AT %date]%newline%newline" type="log4net.Util.PatternString" />
      <ConversionPattern value="%d [%t] %-5p %c - %m%n" />
    </layout>
    <filter type="log4net.Filter.LevelRangeFilter,log4net">
      <levelMin value="ERROR" />
      <levelMax value="FATAL" />
    </filter>
  </appender>
</log4net>

我在controller中, 弄了一个错误点, 还是把代码贴出来吧. 清晰点

public ActionResult Index()
{
    LogHelper.Log("trace").WriteInfo("进入HomeController/Index方法");try
    {
        ;

        ;

        var s = b / a;
    }
    catch (Exception ex)
    {
        string errorMsg = string.Format(@"后台异常信息:【{0}】,
    引发异常的方法:【{1}】,
    引发异常的对象:【{2}】",
                                            ex.Message,  //异常信息
                                            ex.TargetSite.ToString(),   //异常方法名
                                            ex.Source //引发异常的对象
                                            );
        LogHelper.Log("logsys").WriteError(errorMsg);
    }
    LogHelper.Log("trace").WriteInfo("离开HomeController/Index方法");
    return View(list);
}

接下来看一下结果:

1). 看一下生成的目录

 

这里使用的是日期命名的方式, 每天一个文件, 还有一种, 是使用大小限制的方式, 一个文件限制比如10M, 过了10M, 会自动重新生成一个文件.

2). 看一下日志里面记录的内容

这里的例子, 用的都是最简单的方式, 主要是介绍一下使用方法.

2.2 程序中配置的方式

public class LogHelper
{
    static LogHelper()
    {
        XmlConfigurator.Configure(new FileInfo("Log4net.config"));
    }

    private static LogHelper _instance = null;
    private static ILog ILog;

    public static LogHelper Log(Type t)
    {
        if (_instance == null)
            _instance = new LogHelper();

        ILog = LogManager.GetLogger(t);

        return _instance;
    }

    public static LogHelper Log(string sType)
    {
        if (_instance == null)
            _instance = new LogHelper();

        ILog = LogManager.GetLogger(sType);

        return _instance;
    }
    /// <summary>
    /// 写调试信息
    /// </summary>
    /// <param name="msg">消息</param>
    public void WriteDebug(string msg)
    {
        ILog.Debug(msg);
    }

    /// <summary>
    /// 写普通信息
    /// </summary>
    /// <param name="msg">消息</param>
    public void WriteInfo(string msg)
    {
        ILog.Info(msg);
    }

    /// <summary>
    /// 写警告信息
    /// </summary>
    /// <param name="msg">消息</param>
    public void WriteWarn(string msg)
    {
        ILog.Warn(msg);
    }

    /// <summary>
    /// 写错误信息
    /// </summary>
    /// <param name="msg">消息</param>
    public void WriteError(string msg)
    {
        ILog.Error(msg);
    }

    /// <summary>
    /// 写错误信息
    /// </summary>
    /// <param name="msg">消息</param>
    /// <param name="ex">错误信息</param>
    public void WriteError(string msg, Exception ex)
    {
        ILog.Error(msg, ex);
    }

    /// <summary>
    /// 写重大错误信息
    /// </summary>
    /// <param name="msg">消息</param>
    public void WriteFatal(string msg)
    {
        ILog.Fatal(msg);
    }
}

主要是 XmlConfigurator.Configure() 方法. config里面app.config/web.config文件中不加配置, 加这一句话也是可以的.

看一下结果:

这里只有Begin logging , 为啥没有 End logging呢, 这个是logger自动加的, 会在结束的时候加上去的.

Log4net - 项目使用的一个简单Demo的更多相关文章

  1. angular实现了一个简单demo,angular-weibo-favorites

    前面必须说一段 帮客户做了一个过渡期的项目,唯一的要求就是速度,我只是会点儿基础的php,于是就用tp帮客户做了这个项目.最近和客户架构沟通,后期想把项目重新做一下,就用现在最流行的技术,暂时想的使用 ...

  2. 在cengos中安装zabbix server/agent, 并创建一个简单demo

    添加zabbix更新源 rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch ...

  3. 关于EF的一个简单Demo

       今天使用EF的时候很奇怪的问题,添加属性后,使用程序包管理器控制台的NuGet命令更新无效,于是做了这个测试,一次性写好,自动更新,看看效果 1.首先建立一个MVC项目 2.我们选择Intern ...

  4. 用redis来实现Session保存的一个简单Demo

    现在很多项目都用Redis(RedisSessionStateProvider)来保存Session数据,但是最近遇到一个比较典型的情况,需要把用户数据全部load到redis里面,在加上RedisS ...

  5. Android中调用C++函数的一个简单Demo

    这里我不想多解释什么,对于什么JNI和NDK的相关内容大家自己去百度或谷歌.我对Android的学习也只是个新手.废话少说直接进入正题. 一.在Eclipse中创建一个Android Applicat ...

  6. gin框架初识(先跑一个简单demo) ①

    Gin 是一个 go 写的 web 框架,具有高性能的优点.官方地址:https://github.com/gin-gonic/gin 先跑一个demo(先安装gin框架,具体见官方地址): 1.vs ...

  7. 【转】用Pthread创建线程的一个简单Demo

    一.我们直接在COCOS2D-X自带的HelloWorld工程中添加代码.首先将Pthread的文件包含进来包括lib文件.在HelloWorld.cpp中引入头文件和库. #include &quo ...

  8. COCOS2D-X之圆形进度条的一个简单Demo

    这应该是游戏中很常见的一个效果.显示某个事件的进度等,在加载资源或者联网的时候经常用到.所以有必要学习学习 一.我们直接在COCOS2D-X自带的HelloCpp的工程中添加代码即可.我们在初始化中添 ...

  9. 如何使用eclipse创建JAVA项目并写一个简单的HelloWorld

    输入项目名称  点击完成(Finish) 原文地址:https://blog.csdn.net/qq_36798713/article/details/79530056

随机推荐

  1. 微信小程序体验(2):驴妈妈景区门票即买即游

    驴妈妈因为出色的运营能力,被腾讯选为首批小程序内测单位.驴妈妈的技术开发团队在很短的时间内完成了开发任务,并积极参与到张小龙团队的内测问题反馈.驴妈妈认为,移动互联网时代,微信是巨大的流量入口,也是旅 ...

  2. 标准产品+定制开发:专注打造企业OA、智慧政务云平台——山东森普软件,交付率最高的技术型软件公司

    一.公司简介山东森普信息技术有限公司(以下简称森普软件)是一家专门致力于移动互联网产品.企业管理软件定制开发的技术型企业.公司总部设在全国五大软件园之一的济南齐鲁软件园.森普SimPro是由Simpl ...

  3. 路由的Resolve机制(需要了解promise)

    angular的resovle机制,实际上是应用了promise,在进入特定的路由之前给我们一个做预处理的机会 1.在进入这个路由之前先懒加载对应的 .js $stateProvider .state ...

  4. HTTP常用状态码分析

    不管是面试还是工作中,经常会碰到需要通过HTTP状态码去判断问题的情况,比如对于后台RD,给到前端FE的一个接口,出现502或者504 error错误,FE就会说接口存在问题,如果没有知识储备,那就只 ...

  5. 如何利用ETW(Event Tracing for Windows)记录日志

    ETW是Event Tracing for Windows的简称,它是Windows提供的原生的事件跟踪日志系统.由于采用内核(Kernel)层面的缓冲和日志记录机制,所以ETW提供了一种非常高效的事 ...

  6. 关于Visual Studio 未能加载各种Package包的解决方案

    问题: 打开Visual Studio 的时候,总提示未能加载相应的Package包,有时候还无法打开项目,各种提示 解决方案: 进入用户目录 C:\Users\用户名\AppData\Local\M ...

  7. Objective-C枚举的几种定义方式与使用

    假设我们需要表示网络连接状态,可以用下列枚举表示: enum CSConnectionState { CSConnectionStateDisconnected, CSConnectionStateC ...

  8. 设计模式C#合集--单例模式

    单例模式 代码: 第一种: private static Singleton singleton = null; private Singleton() { } public static Singl ...

  9. BPM配置故事之案例11-操作外部数据源

    小明:可以获取ERP数据了-- 老李:哦,这么快?小伙子,我非常看好你,来来,别急着走,再陪我聊会-- 小明:--您老人家不是又要改流程吧? 老李:没有没有,哎嘿嘿嘿,我们这不都是为公司效率着想嘛,这 ...

  10. gulp 自动添加版本号

    本文介绍利用 gulp-rev 和 gulp-rev-collector 进行版本管理 npm官网介绍使用后的效果如下: "/css/style.css" => " ...