3.6、GG_Logs 日志类库封装使用说明

GG_Logs类库项目,Nuget安装log4net

添加代码配置代码:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = false)]

添加操作类代码(Log4Net.cs):

using System;

using System.Collections.Generic;

using System.Diagnostics;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

using log4net;

namespace GG_Logs

{

public static class Log4Net

{

public static void Debug(object message)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Debug(message);

}

public static void Debug(object message, Exception ex)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Debug(message, ex);

}

public static void Error(object message)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Error(message);

}

public static void Error(object message, Exception exception)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Error(message, exception);

}

private static string GetCurrentMethodFullName()

{

try

{

StackFrame frame;

string str2;

int num = 2;

StackTrace trace = new StackTrace();

int length = trace.GetFrames().Length;

do

{

frame = trace.GetFrame(num++);

str2 = frame.GetMethod().DeclaringType.ToString();

}

while (str2.EndsWith("Exception") && (num < length));

string name = frame.GetMethod().Name;

return (str2 + "." + name);

}

catch

{

return null;

}

}

public static void Info(object message)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Info(message);

}

public static void Info(object message, Exception ex)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Info(message, ex);

}

public static void Warn(object message)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Warn(message);

}

public static void Warn(object message, Exception ex)

{

LogManager.GetLogger(GetCurrentMethodFullName()).Warn(message, ex);

}

}

}

在使用的项目中引用类的GG_Logs.dll,新建文件log4net.config 并添加配置代码:

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<configSections>

<section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>

</configSections>

<log4net>

<!-- OFF, FATAL, ERROR, WARN, INFO, DEBUG, ALL -->

<!-- Set root logger level to ERROR and its appenders -->

<root>

<level value="ALL" />

<appender-ref ref="SysAppender" />

</root>

<!-- Print only messages of level DEBUG or above in the packages -->

<logger name="WebLogger">

<level value="DEBUG" />

</logger>

<appender name="SysAppender" type="log4net.Appender.RollingFileAppender,log4net">

<!--文件名称-->

<appendToFile value="true"/>

<param name="File" value="C:/Logs/" />

<param name="AppendToFile" value="true" />

<param name="RollingStyle" value="Date" />

<!--文件名称-->

<param name="DatePattern" value="&quot;Logs_&quot;yyyyMMdd&quot;.txt&quot;" />

<param name="StaticLogFileName" value="false" />

<!--设置无限备份=-1 ,最大备份数为1000-->

<param name="MaxSizeRollBackups" value="1000"/>

<!--每个文件的大小-->

<param name="MaximumFileSize" value="500KB"/>

<layout type="log4net.Layout.PatternLayout,log4net">

<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />

</layout>

</appender>

<appender name="consoleApp" type="log4net.Appender.ConsoleAppender,log4net">

<layout type="log4net.Layout.PatternLayout,log4net">

<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />

</layout>

</appender>

</log4net>

</configuration>

调用代码很简单。

using GG_Logs;

Log4Net.Error("hhhhhhhhhhhhh");

实际项目调用,建立mvc模式的web项目,项目名称Web。

当前mvc项目想创建一个log4net.config 日志配置文件:代码如下

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<configSections>

<section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>

</configSections>

<log4net>

<!-- OFF, FATAL, ERROR, WARN, INFO, DEBUG, ALL -->

<!-- Set root logger level to ERROR and its appenders -->

<root>

<level value="ALL" />

<appender-ref ref="SysAppender" />

</root>

<!-- Print only messages of level DEBUG or above in the packages -->

<logger name="WebLogger">

<level value="DEBUG" />

</logger>

<appender name="SysAppender" type="log4net.Appender.RollingFileAppender,log4net">

<!--文件名称-->

<appendToFile value="true"/>

<param name="File" value="D:/Logs/" />

<param name="AppendToFile" value="true" />

<param name="RollingStyle" value="Date" />

<!--文件名称-->

<param name="DatePattern" value="&quot;Logs_&quot;yyyyMMdd&quot;.txt&quot;" />

<param name="StaticLogFileName" value="false" />

<!--设置无限备份=-1 ,最大备份数为1000-->

<param name="MaxSizeRollBackups" value="1000"/>

<!--每个文件的大小-->

<param name="MaximumFileSize" value="500KB"/>

<layout type="log4net.Layout.PatternLayout,log4net">

<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />

</layout>

</appender>

<appender name="consoleApp" type="log4net.Appender.ConsoleAppender,log4net">

<layout type="log4net.Layout.PatternLayout,log4net">

<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />

</layout>

</appender>

</log4net>

</configuration>

当前项目添加引用

打开HomeController.cs 控制器 ,添加代码

using GG_Logs;  //命名空间引用

Index()方法加入代码Log4Net.Error("hhhhhhhhhhhhh");

运行项目,在D盘logs文件夹下有txt文本,日志操作完成。

需要的可加qq群:547765059  ,源码在空间里。

GG_Logs 日志类库封装使用说明的更多相关文章

  1. quartz.net插件类库封装(含源码)

    1.前言 目录: 1.quartz.net任务调度:源码及使用文档 2.quartz.net插件类库封装 最近项目需要做一写任务作业调度的工作,最终选择了quartz.net这个插件,它提供了巨大的灵 ...

  2. 【转】第7篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:全自动注册与反射方法分析

    作者: 牛A与牛C之间 时间: 2013-12-12 分类: 技术文章 | 2条评论 | 编辑文章 主页 » 技术文章 » 第7篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  3. 【转】第6篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:自动注册JS脚本+自动反射方法分析

    作者: 牛A与牛C之间 时间: 2013-11-21 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第6篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  4. 【转】第5篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:自动注册JS脚本+委托回调方法分析

    作者: 牛A与牛C之间 时间: 2013-11-19 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第5篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  5. 【转】第4篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:委托回调方法分析

    作者: 牛A与牛C之间 时间: 2013-11-18 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第4篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  6. 【转】3篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:官方原生方法分析

    作者: 牛A与牛C之间 时间: 2013-11-17 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第3篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  7. 通过编写一个简单的日志类库来加深了解C#的文件访问控制

    在程序的开发调试过程及发布运行后的状态监控中,日志都有着极其重要的分量,通过在关键逻辑节点将关键数据记录到日志文件当中能帮助我们尽快找到程序问题所在.网上有不少专业成熟的日志组件可用,比如log4ne ...

  8. 日志log4cxx 封装、实例讲解、配置文件log4cxx.properties

    日志log4cxx 封装.实例讲解.配置文件log4cxx.properties 1. 日志作用 程序运行过程中,需要记录程序中的运行状况,方便排查问题,记录数据.可以根据日志的记录快速定位错误发生的 ...

  9. 结构化日志类库 ---- Serilog库

    在过去的几年中,结构化日志已经大受欢迎.而Serilog是 .NET 中最著名的结构化日志类库 ,我们提供了这份的精简指南来帮助你快速了解并运用它. 0. 内容 设定目标 认识Serilog 事件和级 ...

随机推荐

  1. Uva -1515 Pool construction(最小割)

    输入一个字符矩阵,'.'代表洞,'#'代表草地.可以把草改成洞花费为d,或者把洞改成草花费为f,最后还要在草和洞之间修围栏花费为b. 首先把最外一圈的洞变成草,并累加花费. 增加一个源点和一个汇点,源 ...

  2. 1sting 大数 递推

    You will be given a string which only contains ‘1’; You can merge two adjacent ‘1’ to be ‘2’, or lea ...

  3. bzoj2212 Tree Rotations

    被BZOJ坑了一下午,原以为是我程序有问题一直WA,结果是我数组小了...为啥不给我RE!!! 线段树合并,对于逆序对而言,只能通过交换左右子树来达到,那么我们就可以想到对于一个结点而言,我们当然要取 ...

  4. Java并发包——使用新的方式创建线程

    Java并发包——使用新的方式创建线程 摘要:本文主要学习了如何使用Java并发包中的类创建线程. 部分内容来自以下博客: https://www.cnblogs.com/dolphin0520/p/ ...

  5. select语句中会影响查询效率的因素

    1.没有创建索引,或者没有正确使用索引;2.存在死锁的情况,从而导致select语句挂起; 3.返回不必要的列,如很多人喜欢在程序中使用select * from 这样会查询表或视图中的所有字段,如果 ...

  6. 怎样删除Tomcat下已经部署的项目

    lz说的是把web项目部署到tomcat之中,要把它删除..很简单,找到webapps文件(tomcat的根目录)下把它删除即可.. 2.Tomcat 6.0\webapps\项目名 只要在把这个目录 ...

  7. [52ABP系列] - 002、模板项目配合代码生成器开发

    前言 本篇的主要内容是 52ABP SPA模板如何配合52ABP代码生成器开发项目 如果不了解 52ABP 项目请先看我的第一篇文章 [52ABP系列] - 001.SPA免费项目模版搭建教程 话不多 ...

  8. Office 佳能MP259打印EXCEL线条歪曲,字迹模糊怎么办

    这大概是墨盒的缘故,判断方法很简单,随便找一个文档,点击打印,属性   在维护选项卡中把清洗和打印头对齐做一遍(一般字迹模糊可以通过清洗解决,线条歪曲可以通过打印头对齐解决),如果你打印的结果是纸张边 ...

  9. SpringMVC之application-context.xml,了解数据库相关配置

    上一篇SpringMVC之web.xml让我们了解到配置一个web项目的时候,怎样做基础的DispatcherServlet相关配置.作为SpringMVC上手的第一步.而application-co ...

  10. javascript闭包具体解释

    今天我们从内存结构上来解说下 javascript中的闭包概念. 闭包:是指有权訪问另外一个函数作用域中的变量的函数. 创建闭包的常见方式就是在一个函数内部创建另外一个函数. 在javascript中 ...