java log4j 写日志_Java log4j同时写入文本日志和数据库日志

版权声明:转载原创文章请以超链接形式请注明原文章出处,尊重作者,尊重原创!

恰饭广告

Log4jUtil.java

import org.apache.log4j.Logger;

import org.apache.log4j.MDC;

public class Log4jUtil {

private static Logger logger = Logger.getLogger(Log4jUtil.class.getName());

/**

* 增删改动作的日志写入 (谁 操作 什么)

* @param op 用户操作

* @param param 传入参数

*/

public static void logInfo(String op, String param) {

if( (op.equals("")||op==null) || (param.equals("")||param==null)){

System.out.println("没有参数传入");

}

else{

MDC.put("user", "session.id"); // 用户id

MDC.put("operation", op); // 用户操作

MDC.put("param", param); // 接收参数

logger.info("");

MDC.remove("user");

MDC.remove("operation");

MDC.remove("param");

}

}

/**

* 发生异常的日志写入

* @param ex 异常信息

*/

public static void logError(String ex) {

logger.error(ex);

}

}

log4j.properties(放在src目录下)

### 设置级别和目的地(这里多个目的地) ###

log4j.rootLogger = CONSOLE,InfoLog,ErrorLog,logDB

### 输出到控制台 ###

log4j.appender.CONSOLE = org.apache.log4j.ConsoleAppender

log4j.appender.CONSOLE.Target = System.out

log4j.appender.CONSOLE.layout = org.apache.log4j.PatternLayout

log4j.appender.CONSOLE.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{1}:%L [%t:%r]- %m%n

### 输出文件info ###

log4j.logger.infolog = InfoLog

log4j.appender.InfoLog = org.apache.log4j.DailyRollingFileAppender

log4j.appender.InfoLog.File = logs/info.log

log4j.appender.InfoLog.Append = true

log4j.appender.InfoLog.Threshold = INFO

log4j.appender.InfoLog.DatePattern = '.'yyyy-MM

log4j.appender.InfoLog.layout = org.apache.log4j.PatternLayout

log4j.appender.InfoLog.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] - [%X{user} %X{operation} %X{param}] - %m%n

### 输出文件error ###

log4j.logger.errorlog = ErrorLog

log4j.appender.ErrorLog = org.apache.log4j.DailyRollingFileAppender

log4j.appender.ErrorLog.File = logs/error.log

log4j.appender.ErrorLog.Append = true

log4j.appender.ErrorLog.Threshold = ERROR

log4j.appender.ErrorLog.DatePattern = '.'yyyy-MM

log4j.appender.ErrorLog.layout = org.apache.log4j.PatternLayout

log4j.appender.ErrorLog.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss} [ %t\:%r ] - [ %p ] - [%X{user} %X{operation} %X{param} - %m%n

#将日志输出到SQLserver数据库

log4j.appender.logDB = org.apache.log4j.jdbc.JDBCAppender

log4j.appender.logDB.layout = org.apache.log4j.PatternLayout

log4j.appender.logDB.Driver = com.microsoft.sqlserver.jdbc.SQLServerDriver

log4j.appender.logDB.URL = jdbc:sqlserver://localhost:1433;DatabaseName=hibernatetest

log4j.appender.logDB.User = sa

log4j.appender.logDB.Password = 123456

log4j.appender.logDB.Sql =INSERT INTO T_Log(create_date,[level],category,file_name,thread_name,line,all_category,message,[user],operation,param)values('%d{yyyy-MM-dd HH\:mm\:ss}','%p','%c','%F','%t','%L','%l','%m','%X{user}','%X{operation}','%X{param}')

Sql脚本(SQL Server)

CREATE TABLE [dbo].[T_Log](

[id] [int] IDENTITY(1,1) NOT NULL,

[create_date] [datetime] NULL,

[level] [varchar](50) NULL,

[category] [varchar](50) NULL,

[file_name] [varchar](50) NULL,

[thread_name] [varchar](50) NULL,

[line] [int] NULL,

[all_category] [varchar](50) NULL,

[message] [varchar](50) NULL,

[user] [varchar](50) NULL,

[operation] [varchar](50) NULL,

[param] [varchar](50) NULL,

CONSTRAINT [PK_T_Log] PRIMARY KEY CLUSTERED

(

[id] ASC

)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]

) ON [PRIMARY]

GO

相关jar包

log4j.jar、mssql-jdbc.jar

注意:

log4j.properties文件的数据库连接根据自己的数据库来

让我恰个饭吧.ヘ( ̄ω ̄ヘ)

支付宝 ——————- 微信

恰饭广告

b2fa10417bcbd2c397d3c42ce544672e.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355641.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

订单生产计划表范本_工厂生产管理为什么需要ERP软件?

对于工厂来说,规模大了,管理问题也就随之多了,在工厂生产流程中,我们常见的一些生产现象,比如生产计划表徒具形式、各生产部门半成品堆积、生产计划达标率低、前后工序原材料或半成品衔接不上、经常追加或取消生产计划…

codeforces 701 E. Connecting Universities(树+ 边的贡献)

题目链接:http://codeforces.com/contest/701/problem/E 题意:有n个城市构成一棵树,一个城市最多有一个学校,这n个城市一共2*k个学校,要对这2*k个学校进行连边,使得所有连出来的边的和最大,每条…

拜托,Java。 最终是否支持多行字符串文字

我了解Java语言的思想很难以向后兼容的方式进行维护。 我知道JDK API(例如集合)的想法很难打破。 是。 我不明白为什么Java 仍然没有多行字符串文字。 您多久编写一次这样的JDBC代码(或您想嵌入Java的任何其他外部语言或标记,例…

java memorystream 包_MemoryStream

MemoryStream位于System.IO命名空间,为系统内存提供流式的读写操作。常作为其他流数据交换时的中间对象操作。1、MemoryStream类封装一个字节数组,在构造实例时可以使用一个字节数组作为参数,但是数组的长度无法调整。使用默认无参数构造函数…

网站pc端分享QQ好友,空间,微博

在开发pc端网站的过程中,涉及到邀请好友的功能,之前单纯的复制粘贴已经无法满足用户的体验。故,仿照移动端添加自动分享到QQ好友,QQ空间,QQ微博的功能。 分享到QQ好友:http://connect.qq.com/widget/shareq…

python如果选择不在列表里_Python-list.remove(x)x不在列表中

我正在尝试在Python 3.3中创建一个简单的程序,该程序采用四个名称的列表,并将它们随机分配给列表中的另一个人.例如,如果名称是John,Aaron,Lydia和Robin: 约翰先走,然后选择一个名字.他不能画自己的东西.如果他这样做,他会把它放回去并再次抽签.说约翰画了罗宾的名字…

P1266 速度限制

速度限制 洛谷链接 题目大意: 在一个城市中,每条道路有限速和长度,通过一条道路的时间为这条道路的长度除以限制的速度,有的道路不知道限速为多少,那么就按现在的速度走这条路,找出从第一个点到目标点的最短…

dbunit测试dao_用于数据库测试的DBUnit,Spring和注释

dbunit测试dao如果您曾经尝试用Java编写数据库测试,则可能会遇到DBUnit 。 DBUnit允许您设置和拆除数据库,以便它包含可针对其编写测试的一致行。 通常,您可以通过编写一个简单的XML文档来指定要DBUnit插入的行,例如: …

python自动化之正则

import re phoneNumRegexre.compile(r\d\d\d-\d\d\d-\d\d\d\d) mophoneNumRegex.search(My number is 415-555-4242.) print(Phone number found: mo.group()) #######利用括号分组############## phoneNumRegexre.compile(r(\d\d\d)-(\d\d\d-\d\d\d\d)) mophoneNumRegex.searc…

mysql递归查询所有上下节点_非递归打印二叉树的所有路径,保存父节点和孩子节点到底有啥差别...

题目解读题目要求输出二叉树的所有路径(字符串形式),乍一看很简单,不就是二叉树的遍历嘛!其实不然,首先,我们用非递归的方式(C)解决这道题(递归在产品代码中是不允许使用的,其次定位 bug 的时候非常困难)。…

发现大量Java原语集合处理

在阅读博客文章5减少Java垃圾收集开销的技巧时 ,我想起了一个名为Trove的小型Java收集库,该库“为Java提供了高速的常规和原始收集”。 我对应用Trove允许原始类型的集合而不是要求集合中的元素成为完整的引用对象的能力特别感兴趣。 我在这篇文章中会更…

51nod1244 欧拉函数之和 杜教筛

和上一题差不多&#xff0c;一个是μ*Ie&#xff0c;一个是φ*IId 稍改就得到了这题的代码 &#xff08;我会告诉你我一开始逆元算错了吗&#xff09; 1 #include <bits/stdc.h>2 #define MAX 50000003 #define MOD 10000000074 using namespace std;5 long long a,b,N;6…

java7代码示例_Java中的七种排序方式代码示例

packagebaseJava;/*** title SortMethods.java*authorDonsenChen* Date 2018年5月2日 上午10:16:03* Description*/public classSortMethods {public static voidmain(String[] args) {int[] arr { 3, 7, 9, 1, 4, 8, 2, 6, 5};binarySort(arr);bubbleSort(arr);quickSort(arr…

nginx配置多个server_Nginx基本属性配置详解

. Nginx服务的基本配置1.1 用于调试进程和定位问题的配置项是否以守护进程的方式运行nginx# 默认ondaemon on|off;是否以master/worker方式工作# 默认on&#xff0c;指定了是否以master-worker进程的方式运行&#xff0c;如果设置为off&#xff0c;那么所有的请求将只会由maste…

android-DNS服务找不到

1、重启eclipse 2、重新建立AVD 3、在建立AVD时sd卡数值不要填转载于:https://www.cnblogs.com/shouhutian/p/6838327.html

数据增长率怎么算_20年老股民告诉你5个数据可轻松算出股价是否高估

自从开通自媒体以来&#xff0c;有很多朋友问我该如何正确判断股票的合理价格呢&#xff1f;说得太专业&#xff0c;可能很多新入市的股民朋友看不懂。那有没有一种估值方法通俗易懂呢&#xff1f;说实话&#xff0c;真有点为难我了。我首先想到了最简单的PE估值法&#xff0c;…

与Selenium的集成测试

总览 我已经使用了一段时间&#xff0c;并且遇到了一些似乎可以使生活更轻松的事情。 我以为可以将其作为教程分享&#xff0c;所以我将向您介绍这些部分&#xff1a; 使用Maven设置Web项目&#xff0c;配置Selenium以在CI上作为集成测试运行 研究使用“页面对象”为网站中的…

MFC程序打开文件对话框出错的问题解决

前几天从网上下了个图像分析的mfc小程序&#xff0c;是VC6的 用VC6在本地编译生成都没问题。执行起来弹出一个未处理的错误&#xff0c;程序崩溃退出。 想起来原来遇到过打开文件对话框方面的问题&#xff0c;当时项目时间紧张未能深究。 这次要好好看下这个问题。 详细做法就是…

ad 单点登录 java 访问权限_AD 单点登录以及windows认证详细说明

上篇博客我谈到了一些关于ASP.NET Forms身份认证方面的话题&#xff0c;这次的博客将主要介绍ASP.NET Windows身份认证。Forms身份认证虽然使用广泛&#xff0c;不过&#xff0c;如果是在 Windows Active Directory 的环境中使用ASP.NET&#xff0c; 那么使用Windows身份认证也…

index加载显示servlet数据_[WEB篇]-JavaWeb基础与应用-02-Servlet开发

JavaWeb基础与应用2.Servlet开发Servlet是sun公司提供的一门用于开发动态web资源的技术。Sun公司在其API中提供了一个servlet接口&#xff0c;用户若想用发一个动态web资源(即开发一个Java程序向浏览器输出数据)&#xff0c;需要完成以下2个步骤&#xff1a;编写一个Java类&…