1、通过Nuget安装NLog 下载,简单入门 请参照 我刚才转的几篇文章,下面我直接贴代码

2、建表语句

 create table TBL_LOG
(
id VARCHAR2(60) not null,
appname VARCHAR2(20),
modulename VARCHAR2(30),
procname VARCHAR2(30),
operationtype VARCHAR2(20),
logger VARCHAR2(500),
logmessage VARCHAR2(3000) not null,
ip VARCHAR2(32),
longdate VARCHAR2(36),
username VARCHAR2(36),
createdate DATE default sysdate,
loglevel VARCHAR2(12)
)

3、NLog.config,正式运行 throwExceptions="false"

 <?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="true"
internalLogLevel="Info" internalLogFile="d:\work\log1.txt">
<targets async="true">
<target name="database" xsi:type="Database" keepConnection="false" useTransactions="true"
dbProvider="System.Data.OracleClient.OracleConnection,System.Data.OracleClient, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
connectionString="Data Source=ORCL;User Id=oracle;Password=oracle;Integrated Security=no;"
commandText="insert into TBL_LOG(APPNAME,MODULENAME,PROCNAME,OPERATIONTYPE,LOGGER,LOGMESSAGE,IP,LONGDATE,USERNAME,LOGLEVEL) values(:APPNAME,:MODULENAME,:PROCNAME,:OPERATIONTYPE,:LOGGER,:LOGMESSAGE,:IP,:TIME_STAMP,:USERNAME,:LOGLEVEL)">
<parameter name="APPNAME" layout="${event-context:item=APPNAME}" />
<parameter name="MODULENAME" layout="${event-context:item=MODULENAME}" />
<parameter name="PROCNAME" layout="${event-context:item=PROCNAME}" />
<parameter name="OPERATIONTYPE" layout="${event-context:item=OPERATIONTYPE}" />
<parameter name="LOGGER" layout="${event-context:item=LOGGER}" />
<parameter name="LOGMESSAGE" layout="${event-context:item=LOGMESSAGE}" />
<parameter name="IP" layout="${event-context:item=IP}" />
<parameter name="TIME_STAMP" layout="${longdate}" />
<parameter name="USERNAME" layout="${event-context:item=USERNAME}" />
<parameter name="LOGLEVEL" layout="${level:uppercase=true}" />
</target>
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="database" />
</rules>
</nlog>

4、简单封装

     public class Logger
{
#region 初始化
/// <summary>
/// 数据错误无法获取用户时使用
/// </summary>
public static string DefaultUser = "system";
/// <summary>
/// 默认地址
/// </summary>
public static string DefaultIP = "127.0.0.1";
NLog.Logger _logger;
private Logger(NLog.Logger logger)
{
_logger = logger;
}
public Logger(string name) : this(LogManager.GetLogger(name))
{ }
public static Logger Default { get; private set; }
static Logger()
{
Default = new Logger(LogManager.GetCurrentClassLogger());
}
#endregion
#region Process日志写入
/// <summary>
/// 日志写入
/// </summary>
/// <param name="APPNAME">菜单大类</param>
/// <param name="MODULENAME">二级菜单</param>
/// <param name="PROCNAME">本级菜单</param>
/// <param name="OPERATIONTYPE">操作类型</param>
/// <param name="LOGMESSAGE">详细日志</param>
/// <param name="IP">ip地址</param>
/// <param name="USERNAME">用户名</param>
/// <param name="LOGGER">LOGGER</param>
public void Process(string APPNAME, string MODULENAME, string PROCNAME, OperationType OPERATIONTYPE, string LOGMESSAGE, string IP, string USERNAME, string LOGGER)
{
if (LOGMESSAGE.Length > )
{
LOGMESSAGE = LOGMESSAGE.Substring(, );
}
LogEventInfo lei = new LogEventInfo();
lei.Properties["ID"] = Guid.NewGuid().ToString("D");
lei.Properties["APPNAME"] = APPNAME;
lei.Properties["MODULENAME"] = MODULENAME;
lei.Properties["PROCNAME"] = PROCNAME;
lei.Properties["OPERATIONTYPE"] = OPERATIONTYPE;
lei.Properties["LOGMESSAGE"] = LOGMESSAGE;
lei.Properties["IP"] = IP;
lei.Properties["USERNAME"] = USERNAME;
lei.Properties["LOGGER"] = LOGGER;
lei.Level = LogLevel.Info;
_logger.Log(lei);
}
/// <summary>
/// 日志写入,自己传日志类别
/// </summary>
/// <param name="APPNAME">菜单大类</param>
/// <param name="MODULENAME">二级菜单</param>
/// <param name="PROCNAME">本级菜单)</param>
/// <param name="OPERATIONTYPE">操作类型</param>
/// <param name="LOGMESSAGE">详细日志</param>
/// <param name="IP">ip地址</param>
/// <param name="USERNAME">用户名</param>
/// <param name="LOGGER">LOGGER</param>
/// <param name="Level">日志级别</param>
public void Process(string APPNAME, string MODULENAME, string PROCNAME, OperationType OPERATIONTYPE, string LOGMESSAGE, string IP, string USERNAME, string LOGGER, LogLevel Level)
{
if (LOGMESSAGE.Length > )
{
LOGMESSAGE = LOGMESSAGE.Substring(, );
}
LogEventInfo lei = new LogEventInfo();
lei.Properties["ID"] = Guid.NewGuid().ToString("D");
lei.Properties["APPNAME"] = APPNAME;
lei.Properties["MODULENAME"] = MODULENAME;
lei.Properties["PROCNAME"] = PROCNAME;
lei.Properties["OPERATIONTYPE"] = OPERATIONTYPE;
lei.Properties["LOGMESSAGE"] = LOGMESSAGE;
lei.Properties["IP"] = IP;
lei.Properties["USERNAME"] = USERNAME;
lei.Properties["LOGGER"] = LOGGER;
lei.Level = Level;
_logger.Log(lei);
}
#endregion
}
/// <summary>
/// 操作类型枚举
/// </summary>
public enum OperationType
{
/// <summary>
/// 保存或添加
/// </summary>
[System.ComponentModel.Description("保存或添加")]
ADD,
/// <summary>
/// 更新
/// </summary>
[System.ComponentModel.Description("更新")]
UPDATE,
/// <summary>
/// 审核
/// </summary>
[System.ComponentModel.Description("审核")]
AUDIT,
/// <summary>
/// 删除
/// </summary>
[System.ComponentModel.Description("删除")]
DELETE,
/// <summary>
/// 读取/查询
/// </summary>
[System.ComponentModel.Description("读取/查询")]
RETRIEVE,
/// <summary>
/// 登录
/// </summary>
[System.ComponentModel.Description("登录")]
LOGIN,
/// <summary>
/// 查看
/// </summary>
[System.ComponentModel.Description("查看")]
LOOK
}

5、asp.net中的调用列子:

             Logger.Default.Process("系统管理", "权限管理", "用户管理", OperationType.RETRIEVE, "测试写入", Logger.DefaultIP, Logger.DefaultUser, this.GetType().ToString(), NLog.LogLevel.Error);
Logger.Default.Process("系统管理", "权限管理", "用户管理", OperationType.RETRIEVE, "测试写入", Logger.DefaultIP, Logger.DefaultUser, this.GetType().ToString());

NLog 自定义字段 写入 oracle的更多相关文章

  1. [转]NLog 自定义字段 写入 oracle

    本文转自:http://www.cnblogs.com/skyapplezhao/p/5690695.html 1.通过Nuget安装NLog 下载,简单入门 请参照 我刚才转的几篇文章,下面我直接贴 ...

  2. NLog自定义字段写入数据库表,示例

    //自定义字段写入NLog日志 private void saveNLog(InvokeLogModel model) { LogEventInfo ei = new LogEventInfo(); ...

  3. Log4net 自定义字段 写入Oracle 使用ODP.NET Managed驱动

    一.环境说明: 开发工具:vs2010   ,数据库:oracle 11g ,版本:log4net的目前最新版本1.2.13.0    :  Oracle.ManagedDataAccess.dll ...

  4. log4net自定义字段写入SqlServer数据库 ASP.net

    首先申明,本示例经过本作者亲自试验通过,可以运行 第一步 编写log4net配置文件 此处为Log.xml,该文件放在与Web.config平级的位置 <?xml version="1 ...

  5. NetCore2.2使用Nlog自定义日志写入路径配置方式

    在一些特定场景的业务需求下,日志需要写入到不同的路径下提供日志分析.第一种:默认Nlog可以通过日志级别来区分路径,——优点是不需要额外配置,开箱即用——缺点是不够灵活,如果超过级别数量,则不满足需求 ...

  6. Java自定义表单、自定义字段

    最近想实现用户自定义数据库中的字段,我想大部分人第一想到的就是EAV(Entity-Attribute-Value),这种方式对于写一个小的毕业设计应该还可以使用,当然也有很多CMS系统采用这种方式, ...

  7. Log4net 自定义字段到数据库(二)

    这种方法比第一种方法麻烦些 Log4Net.config <?xml version="1.0" encoding="utf-8" ?> <c ...

  8. Hibernate写入Oracle Date类型处理

    Hibernate写入Oracle数据库时,数据库设计字段为Date类型时,只能保存年月日,不能保存时分秒,如果要保存时分秒,需修改Hibernate.cfg.xml文件 <property n ...

  9. Log4net 使用之 自定义字段

    Log4net 是.Net下一个非常优秀的开源日志记录组件.Log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介. 由于业务需要,计划为日志增加2个字段,除了 ...

随机推荐

  1. WEB安全入门(转)

    一. 首先你得了解Web Web分为好几层,一图胜千言:事实是这样的:如果你不了解这些研究对象是不可能搞好安全研究的.这样看来,Web有八层(如果把浏览器也算进去,就九层啦,九阳神功……)!!!每层都 ...

  2. google chrome set

    "D:\Program Files\Google\Chrome\Application\chrome_bk.exe" --start-maximized --user-data-d ...

  3. C++ Web Service SDK

    https://github.com/zaphoyd/websocketpp https://github.com/aws/aws-sdk-cpp

  4. mysql安装出现error Nr.1045 (转)

    http://www.cnblogs.com/Ivan-j2ee/archive/2012/09/22/2698278.html 我们在windows下安装mysql时会出现Access denied ...

  5. unity4.6 failed to update unity web player

    unity4.6 failed to update unity web player 新升级的 4.6.2P2 版本修复了IOS很多的bug. 但突然发现导出的Web版本反而不能工作了. “faile ...

  6. Android debug时一直处于waiting for debugger解决办法

    问题:android 调试卡在:Waiting for Debugger - Application XXX is waiting for the debugger to Attach" 解 ...

  7. nodejs 常用全局包

    1.nodemon 更改node程序后程序自动启动 (nodemon app.js) npm install nodemon  -g 2.gulp 压缩合并代码等 npm install gulp - ...

  8. [mysql]MySQL忘记密码

    1.修改MySQL的登录设置: vi /etc/my.cnf 在[mysqld]的段中加上一句:skip-grant-tables 保存并且退出vi. 2.重新启动mysqld # /etc/init ...

  9. 2 Servlet基础

    作者:禅楼望月(http://www.cnblogs.com/yaoyinglong) 1. 从浏览器访问Servlet的流程 刚才发现,这里的图片不能正常显示,所以我给个链接,大家可以下载下来看从浏 ...

  10. C# 通过Get、Post、Soap调用WebService的方法

    实现代码来源于网络,我只是作了一些修改! using System; using System.Web; using System.Xml; using System.Collections; usi ...