C# log4net 日志写入到数据库
效果图:
1:第一步创建SQL表结构
- 123456789101112131415161718192021
CREATE TABLE [dbo].[LogDetails] ([LogID]intNOT NULL IDENTITY(1,1) ,[LogDate] datetime NOT NULL ,[LogThread] nvarchar(100) NOT NULL ,[LogLevel] nvarchar(200) NOT NULL ,[LogLogger] nvarchar(500) NOT NULL ,[LogMessage] nvarchar(3000) NOT NULL ,[LogActionClick] nvarchar(4000) NULL ,[UserName] nvarchar(30) NULL ,[UserIP] varchar(20) NULL)2:创建项目然后下载log4net.dll 在项目中添加引用http://logging.apache.org/log4net/download_log4net.cgi下载Binaries 下面的
3:创建 log4net.config
- 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
<?xml version="1.0"encoding="utf-8"?><log4net debug="false"><!-- name属性指定其名称,type则是log4net.Appender命名空间的一个类的名称,意思是,指定使用哪种介质--><appender name="ADONetAppender"type="log4net.Appender.ADONetAppender"><!--日志缓存写入条数 设置为0时只要有一条就立刻写到数据库--><bufferSize value="0"/><!--日志数据库连接串--><connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/><connectionString value="DATABASE=GoodLook;SERVER=xx.xx.140.170;UID=sa;PWD=123456a;Connect Timeout=30;"/><!--日志数据库脚本--><commandText value="INSERT INTO LogDetails ([LogDate],[LogThread],[LogLevel],[LogLogger],[LogActionClick],[LogMessage],[UserName],[UserIP]) VALUES (@log_date, @thread, @log_level, @logger, @ActionsClick, @message,@UserName,@UserIP)"/><!--日志时间LogDate --><parameter><parameterName value="@log_date"/><dbType value="DateTime"/><layout type="log4net.Layout.RawTimeStampLayout"/></parameter><!--线程号--><parameter><parameterName value="@thread"/><dbType value="String"/><size value="100"/><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%t"/></layout></parameter><!--日志类型LogLevel --><parameter><parameterName value="@log_level"/><dbType value="String"/><size value="200"/><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%p"/></layout></parameter><!--日志名称--><parameter><parameterName value="@logger"/><dbType value="String"/><size value="500"/><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%logger"/></layout></parameter><parameter><parameterName value="@message"/><dbType value="String"/><size value="3000"/><layout type="Log4NetApply.MyLayout"><conversionPattern value="%property{Message}"/></layout></parameter><parameter><parameterName value="@ActionsClick"/><dbType value="String"/><size value="4000"/><layout type="Log4NetApply.MyLayout"><conversionPattern value ="%property{ActionsClick}"/></layout></parameter><!--自定义UserName --><parameter><parameterName value="@UserName"/><dbType value="String"/><size value="30"/><layout type="Log4NetApply.MyLayout"><!--log4net.MDC.Set("UserName","asdfasdf");<conversionPattern value ="%X{UserName}"/>--><conversionPattern value ="%property{UserName}"/></layout></parameter><parameter><parameterName value="@UserIP"/><dbType value="String"/><size value="20"/><layout type="Log4NetApply.MyLayout"><conversionPattern value ="%property{UserIP}"/></layout></parameter></appender><!-- setup the root category, add the appenders andsetthedefaultlevel --><root><level value="Warn"/><!-- 定义记录的日志级别--><level value="Info"/><level value="Debug"/><level value="Fine"/><appender-refref="ADONetAppender"/><!-- 记录到什么介质中--></root><!-- specify the levelforsome specific categories --><!--//关于上边root到logger这块,如果同时出现,有可能会出现重复插入记录的情况:--><!--<logger name="iNotes"><level value="WARN"/><level value="INFO"/><level value="DEBUG"/><level value="FINE"/><appender-refref="ADONetAppender"/></logger><logger name="StellaLogger"><level value="ALL"/><appender-refref="AdoNetAppender"/></logger>--><appender name="ReflectionLayout"type="log4net.Appender.RollingFileAppender,log4net"><!--日志文件路径,按文件大小方式输出时在这里指定文件名,并且前面的日志按天在文件名后自动添加当天日期形成文件--><param name="File"value="D:/Log/"/><!--是否追加到文件--><param name="AppendToFile"value="true"/><!--记录日志写入文件时,不锁定文本文件--><!--<lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>--><!--Unicode编码--><!--<Encoding value="UTF-8"/>--><!--最多产生的日志文件数,value="-1"为不限文件数--><!--<param name="MaxSizeRollBackups"value="10"/>--><!--是否只写到一个文件中--><param name="StaticLogFileName"value="false"/><!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])--><param name="RollingStyle"value="Composite"/><!--按日期产生文件夹,文件名[在日期方式与混合方式下使用]--><param name="DatePattern"value="yyyy-MM-dd/"ReflectionLayout.log""/><!--<param name="DatePattern"value="yyyyMMdd/yyyyMMdd"-TimerServer.log""/>--><!--<param name="DatePattern"value="yyyyMMdd/"TimerServer/TimerServer.log""/>--><!--每个文件的大小。只在混合方式与文件大小方式下使用,超出大小的在文件名后自动增加1重新命名--><param name="maximumFileSize"value="500KB"/><!--记录的格式。--><layout type="TGLog.ExpandLayout2.ReflectionLayout,TGLog"><param name="ConversionPattern"value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger 操作者ID:%property{Operator} 操作类型:%property{Action}%n 当前机器名:%property%n当前机器名及登录用户:%username %n 记录位置:%location%n 消息描述:%property{Message}%n 异常:%exception%n 消息:%message%newline%n%n"/></layout></appender></log4net>
4:在Web.config 里面加 configSections 节点 (CS可直接写在app.config里面,或者都写在一个config里面)
- 1234567891011121314151617181920212223
<configuration><strong> <span style="color:#FF0000;"> <configSections><section name="log4net"type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/></configSections><log4net configSource="log4net.config"/></span></strong><system.web><compilation debug="true"targetFramework="4.5"/><httpRuntime targetFramework="4.5"/></system.web></configuration>
5:Properties 属性下面的AssemblyInfo.cs 追加 必须有这个,否则写入不到数据库中
- 12345
//[assembly: log4net.Config.XmlConfigurator(Watch = true)]//注意: ConfigFile 可以指定相对路径 和 绝对路径。 eg: /log/xxxx.log 或者 d://log//xxxx.log[assembly: log4net.Config.XmlConfigurator(ConfigFile ="log4net.config", ConfigFileExtension ="config", Watch =true)]
6:添加 Global.asax
然后在Application_Start 追加 读取配置程序文件
- 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
protectedvoidApplication_Start(objectsender, EventArgs e){//应用程序启动时,自动加载配置log4NetXmlConfigurator.Configure();}7:创建自定义类 LogPublicClass.cs,为了方便写入数据库中 自定义的一些信息usinglog4net.Layout;usinglog4net.Layout.Pattern;usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Reflection;usingSystem.Web;namespaceLog4NetApply{/// <summary>/// 包含了所有的自定字段属性/// </summary>publicclassLogContent{publicLogContent(stringmacAddress,stringcomputerName,stringactionsclick,stringdescription){UserIP = macAddress;UserName = computerName;ActionsClick = actionsclick;Message = description;}/// <summary>/// 访问IP/// </summary>publicstringUserIP {get;set; }/// <summary>/// 系统登陆用户/// </summary>publicstringUserName {get;set; }/// <summary>/// 动作事件/// </summary>publicstringActionsClick {get;set; }/// <summary>/// 日志描述信息/// </summary>publicstringMessage {get;set; }}publicclassMyLayout : PatternLayout{publicMyLayout(){this.AddConverter("property",typeof(LogInfoPatternConverter));}}publicclassLogInfoPatternConverter : PatternLayoutConverter{protectedoverridevoidConvert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent){if(Option !=null){// Write the value for the specified keyWriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));}else{// Write all the key value pairsWriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());}}/// <summary>/// 通过反射获取传入的日志对象的某个属性的值/// </summary>/// <param name="property"></param>/// <returns></returns>privateobjectLookupProperty(stringproperty, log4net.Core.LoggingEvent loggingEvent){objectpropertyValue =string.Empty;PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);if(propertyInfo !=null)propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject,null);returnpropertyValue;}}}
8:示例使用
- 1234567891011121314151617
try{log.Info(newLogContent("127.0.0.1","111111","登陆系统","登陆成功"));varss = 1 -int.Parse("sss");}catch(Exception ex){log.Error(newLogContent("127.0.0.1","111111","登陆系统", ex.Message+":"+ex.StackTrace));}
其他自行参考下列文章
- 12345678
http://www.cnblogs.com/kissazi2/p/3393151.htmlhttp://blog.csdn.net/zdw_wym/article/details/48802821http://blog.csdn.net/ydm19891101/article/details/50561638http://www.cnblogs.com/yuangang/archive/2016/05/16/5497140.html
C# log4net 日志写入到数据库的更多相关文章
- C# 利用log4net 把日志写入到数据库表中
效果图: 1:第一步创建SQL表结构 CREATE TABLE [dbo].[LogDetails] ( [LogID] int NOT NULL IDENTITY(1,1) , [LogDat ...
- C# 利用log4net 把日志写入到数据库
效果图: 1:第一步创建SQL表结构 CREATE TABLE [dbo].[LogDetails] ( [LogID] int NOT NULL IDENTITY(1,1) , [Log ...
- 使用log4net 日志输出到数据库MySQL
使用Log4Net的输出日志到MySQL 使用步骤如下: 1. 添加引用Log4Net.dll, mysql.data.dll到工程中 note: mysql.data.dll 版本要高,最好到mys ...
- log4net 日志写入MongoDB 实现分布式日志
本人在.net framework 4.5下测试成功,首先需要安装log4mongo-net组件,见https://www.nuget.org/packages/log4mongo-net/ vs20 ...
- webservice log4net日志写入失败
原因1:如果webservice和调用者都部署在一台机器上,日志有可能写到了项目所在目录中,虽然你添加的服务引用是部署在iis下的,但不会写到这.暂时解决办法,把webservice部署到内网服务器上 ...
- spring boot使用log4j2将日志写入mysql数据库
log4j2官方例子在spring boot中报错而且还是用的是org.apache.commons.dbcp包 我给改了一下使用org.apache.commons.dbcp2包 1.log4j2. ...
- logback日志写入数据库(mysql)配置
如题 建议将日志级别设置为ERROR.这样可以避免存储过多的数据到数据中. 1 logback 配置文件(如下) <?xml version="1.0" encoding ...
- mySql---logback日志写入数据库(mysql)配置
如题 建议将日志级别设置为ERROR.这样可以避免存储过多的数据到数据中. 1 logback 配置文件(如下) <?xml version="1.0" encoding ...
- 使用log4j让日志写入数据库
之前做的一个项目有这么个要求,在日志管理系统里,需要将某些日志信息存储到数据库里,供用户.管理员查看分析.因此我就花了点时间搞了一下这一功能,各位请看. 摘要:我们知道log4j能提供强大的可配置的记 ...
随机推荐
- css图标与文字对齐实现方法
1.移动端(安卓设备.ios设备)图标文字垂直居中对齐的最佳常用解决方案是采用弹性盒子布局,可以快捷有效实现子元素未知高度绝对垂直居中对齐.PC端考虑到兼容性的问题,一般不推荐使用弹性盒子,依旧只能采 ...
- Linux学习-通过loganalyzer展示MySQL中rsyslog日志
一.实验环境 系统:CentOS7.6 软件包:apache,php,mariadb-server (都是基于光盘yum源) 源码包:loganalyzer-4.1.7.tar.gz (http:// ...
- Oracle 与 ODAC 一起安装
Oracle 需要设置path变量支持运行,ODAC安装时会将其路径加入path变量. 导致先搜索到ODAC,连接出现:ora-12560: TNS:protocol adapter error 将p ...
- luogu P1037 产生数 x
P1037 产生数 题目描述 给出一个整数 n(n<10^30) 和 k 个变换规则(k<=15). 规则: 一位数可变换成另一个一位数: 规则的右部不能为零. 例如:n=234.有规则( ...
- android 小游戏 ---- 数独(二)
> 首先创建一个自己的View类 -->继承SurfaceView并实现SurfaceHolder.Callback接口 --> SurfaceView.getHolder ...
- Educational Codeforces Round 16 D. Two Arithmetic Progressions (不互质中国剩余定理)
Two Arithmetic Progressions 题目链接: http://codeforces.com/contest/710/problem/D Description You are gi ...
- WCF - Hosting WCF Service 四种托管方式
https://www.tutorialspoint.com/wcf/wcf_hosting_service.htm After creating a WCF service, the next st ...
- mysqlbinlog读懂binlog
binlog 报unknown variable 'default-character-set=utf8' 方法1: 在/etc/my.cnf 中将default-character-set=utf8 ...
- Oracle 10046 event
http://czmmiao.iteye.com/blog/1497509 10046事件概述Oracle的10046事件,可以跟踪应用程序所执行的SQL语句,并且得到其解析次数.执行次数,CPU使用 ...
- LeetCode 47——全排列 II
1. 题目 2. 解答 在 LeetCode 46--全排列 中我们已经知道,全排列其实就是先确定某一个位置的元素,然后余下就是一个子问题.在那个问题中,数据没有重复,所以数据中的任意元素都可以放在最 ...