Log4j简单配置

Log4j简单配置Log4j是一组强大的日志组件,在项目中时常需要用它提供一些信息,这两天学习了一下它的简单配置。第一步,我们需要导入log4j-1.2.14.jar到lib目录下第二步,在src下建立log4j.pr

大家好,又见面了,我是你们的朋友全栈君。

Log4j是一组强大的日志组件,在项目中时常需要用它提供一些信息,这两天学习了一下它的简单配置。

第一步,我们需要导入log4j-1.2.14.jar到lib目录下

第二步,在src下建立log4j.properties文件。添加如下内容

 1 log4j.properties
 2 log4j.rootLogger =INFO,stdout
 3 log4j.logger.sedion=INFO,db
 4 log4j.logger.W=WARN,W
 5 log4j.logger.E=ERROR,E
 6 
 7 #输出到控制台
 8 log4j.appender.stdout = org.apache.log4j.ConsoleAppender
 9 log4j.appender.stdout.Target = System.out
10 log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
11 log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{1}:%L - %m%n
12 
13 #输出WARN级别日志
14 log4j.appender.W =org.apache.log4j.RollingFileAppender
15 log4j.appender.W.File =${catalina.home}/logs/Test/Test_W.log
16 log4j.appender.W.Append =true
17 log4j.appender.W.Threshold =WARN
18 log4j.appender.W.layout = org.apache.log4j.PatternLayout
19 log4j.appender.W.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
20 
21 #输出ERROR级别日志
22 log4j.appender.E = org.apache.log4j.RollingFileAppender
23 log4j.appender.E.File = ${catalina.home}/logs/Test/Test_E.log
24 log4j.appender.E.Append = true
25 log4j.appender.E.layout = org.apache.log4j.PatternLayout
26 log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ]  %m%n
27  
28 #######################
29  
30 # JDBC Appender  
31  
32 ####################### 
33 log4j.appender.db=org.apache.log4j.jdbc.JDBCAppender
34 log4j.appender.db.BufferSize=1
35 log4j.appender.db.driver=com.mysql.jdbc.Driver
36 log4j.appender.db.URL=jdbc:mysql://localhost:3306/test
37 log4j.appender.db.user=root
38 log4j.appender.db.password=123
39 log4j.appender.db.sql=insert into operate_log(class,method,createtime,loglevel,logmsg,username) values ("%C","%M","%d{yyyy-MM-dd HH\:mm\:ss}","%p","%m","%X{username}")
40 log4j.appender.db.layout=org.apache.log4j.PatternLayout

新建一个数据库test和一张日志表operate_log。

<span role="heading" aria-level="2">Log4j简单配置


可以看到数据库中有个username动态字段,所以我们要写个过滤器
 1 package config.filter;
 2 
 3 import java.io.IOException;
 4 
 5 import javax.servlet.Filter;
 6 import javax.servlet.FilterChain;
 7 import javax.servlet.FilterConfig;
 8 import javax.servlet.ServletException;
 9 import javax.servlet.ServletRequest;
10 import javax.servlet.ServletResponse;
11 import javax.servlet.http.HttpServletRequest;
12 
13 import org.apache.log4j.MDC;
14 
15 
16 public class Log4jFilter implements Filter
17 {
18     private final static int DEDAULT_USERID = 0;
19     public void destroy()
20     {
21         
22     }
23 
24     public void doFilter(ServletRequest req, ServletResponse rep,
25             FilterChain chain) throws IOException, ServletException 
26     {
27         HttpServletRequest request = (HttpServletRequest)req;
28         String username = request.getParameter("username");
29         
30         if(username == null)
31         {
32             MDC.put("username", DEDAULT_USERID);
33         }
34         else
35         {                    
36                 System.out.println("登陆名--"+username);
37                 MDC.put("username", username);            
38         }
39         
40         
41         chain.doFilter(req, rep);
42     }
43 
44     public void init(FilterConfig arg0) throws ServletException 
45     {
46         
47     }
48 
49 
50 }

然后需要在web.xml中进行log4j.properties和过滤器的配置.

<!-- log4j配置 -->
    <context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>classpath:log4j.properties</param-value>
    </context-param>
 
    <listener>
       <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>
    <!-- 过滤器配置 -->
     <filter> 
        <filter-name>LogResFilter</filter-name> 
        <filter-class>config.filter.Log4jFilter</filter-class> 
    </filter>
    <filter-mapping>
        <filter-name>LogResFilter</filter-name>
        <url-pattern>*.do</url-pattern>
    </filter-mapping>

 

第三步,至此我们配置已经全部完成,简单写个登陆来验证一下。

jsp页面很简单,代码便不列出来了.

<span role="heading" aria-level="2">Log4j简单配置

写个登陆实现类.

package sedion.zhr.controller;

import java.util.List;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import sedion.zhr.beans.UserBean;
import sedion.zhr.service.iml.UserServiceIml;

@Controller
@RequestMapping("/action")
public class LoginController 
{
    
    private static final Logger log_w= Logger.getLogger("W");
    private static final Logger log_e = Logger.getLogger("E");
    private Log logger = LogFactory.getLog(this.getClass());  
    
    @Resource(name = "UserService")
    private UserServiceIml serviceIml;
 
    @RequestMapping("/login.do")
    public String login(UserBean bean,HttpServletRequest request,HttpServletResponse response) throws Exception
    {
         
        List<UserBean> beans = this.serviceIml.finduser(new String[]{bean.getUsername(),bean.getPassword()});
     
        if(!beans.isEmpty())
        {            
            log_w.warn("登陆成功--");
            logger.info("登陆成功");

            return "/index";
        }
        else
        {
            log_e.error("登陆失败--");            
            logger.error("登陆失败");
            return "/login";
        }
      
    }

}

将项目配置到tomcat上,启动项目.

可以看到在安装tomcat文件夹下的logs文件夹里面出现个Test文件夹,里面有两个文本,初始大小都是0kb.<span role="heading" aria-level="2">Log4j简单配置

然后我们各登陆成功,登陆失败一次。观察到控制台上输出


 

<span role="heading" aria-level="2">Log4j简单配置


 

然后发现先前两个文本大小变为1kb,里面各有成功失败的信息。

打开数据库表里面多了两条数据。

<span role="heading" aria-level="2">Log4j简单配置

测试成功。

最后记录一下log4j配置中相关属性

log4j日志常见输出级别有4级,由高到低依次是ERROR、WARN、INFO、DEBUG。

日志输出目的地

  •   org.apache.log4j.HTMLLayout(以HTML表格形式布局),
  • <span role="heading" aria-level="2">Log4j简单配置org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
  • <span role="heading" aria-level="2">Log4j简单配置org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
  • <span role="heading" aria-level="2">Log4j简单配置org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

打印参数

  •         %m   输出代码中指定的消息
  • <span role="heading" aria-level="2">Log4j简单配置  %p   输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 
  • <span role="heading" aria-level="2">Log4j简单配置  %r   输出自应用启动到输出该log信息耗费的毫秒数 
  • <span role="heading" aria-level="2">Log4j简单配置  %c   输出所属的类目,通常就是所在类的全名 
  • <span role="heading" aria-level="2">Log4j简单配置  %t   输出产生该日志事件的线程名 
  • <span role="heading" aria-level="2">Log4j简单配置  %n   输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n” 
  • <span role="heading" aria-level="2">Log4j简单配置  %d   输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式
  • <span role="heading" aria-level="2">Log4j简单配置  %l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

 

 




 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/154474.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 批量给图片重命名_图片快速重命名编号

    批量给图片重命名_图片快速重命名编号如果你是一名摄影师,又或者你是一名图片设计的工作人员,工作中肯定会面对很多图片文件,图片多了就需要进行整理,不然就很难区分和管理,就很不利于我们的使用。为了更好的整理往往我们就需要给图片进行重命名并且排序,这就出现一个问题了,如何批量重命名这些图片并且进行编号呢?如果你还不知道如何解决这个问题,那么你就要跟随小编的步伐,我来为大家详细介绍图片批量重命名编号的方法吧!需要使用的软件:优速文件批量重命名软件下载地址:免费下载优速文件批量重命名软件https://www.yososoft.com/do

  • 全部覆盖棋盘7×7_acwing题库

    全部覆盖棋盘7×7_acwing题库给定一个 N 行 N 列的棋盘,已知某些格子禁止放置。求最多能往棋盘上放多少块的长度为 2、宽度为 1 的骨牌,骨牌的边界与格线重合(骨牌占用两个格子),并且任意两张骨牌都不重叠。输入格式第一行包含两个整数 N 和 t,其中 t 为禁止放置的格子的数量。接下来 t 行每行包含两个整数 x 和 y,表示位于第 x 行第 y 列的格子禁止放置,行列数从 1 开始。输出格式输出一个整数,表示结果。数据范围1≤N≤100,0≤t≤100输出样例:8 0输出样例:32#include&l

  • https加密原理(转)

    https加密原理(转)HTTP、HTTPS在我们日常开发中是经常会接触到的。我们也都知道,一般Android应用开发,在请求API网络接口的时候,很多使用的都是HTTP协议;使用浏览器打开网页,也是利用HTTP协议。看来HTTP真是使用广泛啊,但是,HTTP是不安全的。利用网络抓包工具就可以知道传输中的内容,一览无余。比如我经常会使用Fiddler来抓包,搜集一些有趣的API接口。那么…

  • java中接口的定义与实现

    java中接口的定义与实现

    2021年11月13日
  • 权限设计-系统登录用户权限设计[通俗易懂]

    权限设计-系统登录用户权限设计[通俗易懂]需求分析—场景假设需要为公司设计一个人员管理系统,并为各级领导及全体员工分配系统登录账号。有如下几个要求:1. 权限等级不同:公司领导登录后可查看所有员工信息,部门领导登录后只可查看本部门员工的信息,员工登录后只可查看自己的信息;2.访问权限不同:如公司领导登录后,可查看员工薪水分布界面,而员工则不能看到;3.操作权限不同:如系统管理员可以在信息发布界面进行增删改查发布信息

  • hive数据库数据类型_hive decimal类型

    hive数据库数据类型_hive decimal类型下面介绍几种常用的数据类(1)CHAR()该数据类型用于定义固定长度的字符串,其中用于指定字符串的最大长度,必须是正整数且不超过32767。使用CHAR类型定义变量时,如果没有指定则默认值为1。需要注意的是,在PL/SQL块中,使用该数据类型操纵CHAR表列时,其数值的长度不应超过2000字节。(2)VARCHAR2()该数据类型用于定义可变长度的字符串,其中用于指定字符串的最大长度,必须是正整数且不超过32767。使用VARCHAR2类型定义变量时,必须指定的值。需要注意的是,在P…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号