zoukankan      html  css  js  c++  java
  • springboot添加log4j日志配置log4j.xml生成日志文件

    第一步:添加pom文件依赖

    <!-- log4j -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-log4j</artifactId>
                <version>1.3.8.RELEASE</version>
            </dependency>
            <dependency>
                <groupId>commons-lang</groupId>
                <artifactId>commons-lang</artifactId>
                <version>2.6</version>
            </dependency>

    第二步:在resources目录下新建一个log4j.xml文件

    log4j.xml:

    注:

    org.apache.log4j.ConsoleAppender(控制台),  

    org.apache.log4j.FileAppender(文件),  

    org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),  

    org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  

    org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE log4j:configuration SYSTEM "http://toolkit.alibaba-inc.com/dtd/log4j/log4j.dtd">
    
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    
        <appender name="CONSOLE-APPENDER" class="org.apache.log4j.ConsoleAppender">
            <param name="encoding" value="UTF-8" />
            <param name="threshold" value="debug"></param>
            <layout class="org.apache.log4j.PatternLayout">
                <param name="ConversionPattern" value="%d %-5p %-32t - %m%n" />
            </layout>
        </appender>
        <appender name="DEFAULT-APPENDER" class="org.apache.log4j.DailyRollingFileAppender">
            <param name="file" value="./logs/default.log"/>
            <param name="append" value="true"/>
            <param name="encoding" value="UTF-8"/>
            <param name="threshold" value="debug"/>
            <layout class="org.apache.log4j.PatternLayout">
                <param name="ConversionPattern" value="%d %-5p %-32t - %m%n"/>
            </layout>
        </appender>
    
        <appender name="ERROR-APPENDER" class="org.apache.log4j.DailyRollingFileAppender">
            <param name="file" value="./logs/error.log"/>
            <param name="append" value="true"/>
            <param name="encoding" value="UTF-8"/>
            <param name="threshold" value="error"/>
            <layout class="org.apache.log4j.PatternLayout">
                <param name="ConversionPattern" value="%d %-5p %-32t - %m%n"/>
            </layout>
        </appender>
    
    
        
        <appender name="HOSPITAL-WEB" class="org.apache.log4j.DailyRollingFileAppender">
            <param name="file" value="./logs/web.log" />
            <param name="append" value="true" />
            <param name="encoding" value="UTF-8" />
            <param name="threshold" value="debug" />
            <layout class="org.apache.log4j.PatternLayout">
                <param name="ConversionPattern" value="%d %-5p %-32t - %m%n" />
            </layout>
        </appender>
        
        <logger name="yxm.zyf.love" additivity="false"><!-包名->
            <level value="debug" /> <!-debug日志太多了可以改成info级别打印日志->
            <appender-ref ref="HOSPITAL-WEB" />
            <appender-ref ref="ERROR-APPENDER" />
        </logger>
    
      <!--   <logger name="yxm.zyf.love" additivity="false">
            <level value="debug" />
            <appender-ref ref="CONSOLE-APPENDER" />
            <appender-ref ref="ERROR-APPENDER" />
            <appender-ref ref="DEFAULT-APPENDER" />
        </logger> -->
    
        <root>
            <level value="debug" />
            <appender-ref ref="CONSOLE-APPENDER" />
            <appender-ref ref="ERROR-APPENDER" />
            <appender-ref ref="DEFAULT-APPENDER" />
        </root>
    
    </log4j:configuration>

    第三步:给大家一个工具类参考一下,封装了4个级别的日志

    import java.text.MessageFormat;
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import org.apache.log4j.Logger;
    
    
    /**
     * @author Zhangyufeng
     *
     */
    public class LoggerUtil {
    
        private static final String TRACE_MARKER = "[TraceId:{0}] ";
    
        /**
         * 生成trace的模板
         * 
         * @param template
         * @param parameters
         * @return
         */
        public static String getMessage(String template, Object... parameters) {
    
            return MessageFormat.format(TRACE_MARKER, getTraceId()) + MessageFormat.format(template, parameters);
        }
    
        /**
         * <p>
         * 生成调试级别日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成debug级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void debug(Logger logger, String template, Object... parameters) {
            if (logger.isDebugEnabled()) {
                logger.debug(getMessage(template, parameters));
            }
        }
    
        /**
         * <p>
         * 生成调试级别日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成info级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void info(Logger logger, String template, Object... parameters) {
            if (logger.isInfoEnabled()) {
                logger.info(getMessage(template, parameters));
            }
        }
    
        /**
         * <p>
         * 生成调试级别日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成warn级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void warn(Logger logger, String template, Object... parameters) {
            logger.warn(getMessage(template, parameters));
        }
    
        /**
         * <p>
         * 生成调试级别日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成error级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void error(Logger logger, String template, Object... parameters) {
            logger.error(getMessage(template, parameters));
        }
    
        /**
         * <p>
         * exception日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成warn级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void warn(Throwable e, Logger logger, String template, Object... parameters) {
            logger.warn(getMessage(template, parameters), e);
        }
    
        /**
         * <p>
         * exception日志
         * </p>
         * <p>
         * 根据带参数的日志模板和参数集合,生成error级别日志
         * 带参数的日志模板中以{数字}表示待替换为变量的日志点,如a={0},表示用参数集合中index为0的参数替换{0}处
         * </p>
         *
         * @param logger
         *            logger引用
         * @param template
         *            带参数的日志模板
         * @param parameters
         *            参数集合
         */
        public static void error(Throwable e, Logger logger, String template, Object... parameters) {
            logger.error(getMessage(template, parameters), e);
        }
    
        /**
         * traceid
         * 
         * @return
         */
        private static String getTraceId() {
            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");//格式化对象
            String tempD = sdf.format(new Date());
            return tempD+((int) (Math.random() * 900) + 100);
        }
    }

    第四部:创建日志对象

    import java.util.Map;
    import javax.servlet.http.HttpServletRequest;
    import org.apache.log4j.Logger;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.RequestBody;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    import org.springframework.web.bind.annotation.RestController;
    
    import com.alibaba.fastjson.JSON;
    
    import yxm.zyf.love.domian.RoomDO;
    import yxm.zyf.love.mapper.RoomMapper;
    import yxm.zyf.love.utils.LoggerUtil;
    import yxm.zyf.love.utils.StringUtil;
    import yxm.zyf.love.utils.URLencord;
    import yxm.zyf.love.vo.payVo;
    
    @RestController
    public class hospitalpay {
        private final static Logger logger = Logger.getLogger(hospitalpay.class);//给类初始化日志对象
        
        @Autowired
        private RoomMapper roomMapper;
        
        @ResponseBody
        @RequestMapping(value = "pay")
        public void pay(HttpServletRequest req, @RequestBody String a) {
            System.out.println(req.getAttribute("industry"));
            System.out.println(req.getParameter("industry"));
            Map<String, Object> map = StringUtil.transStringToMap(URLencord.URLDecoderString(a), "&", "=");
            for (String key : map.keySet()) {
                System.out.println("key:" + key + ", value:" + map.get(key));
            }
            System.out.println(map);
            System.out.println(JSON.parseObject(JSON.toJSONString(map)));
            payVo payvo=JSON.parseObject(JSON.toJSONString(map), payVo.class);
            System.out.println(payvo);
        }
        
        @ResponseBody
        @RequestMapping(value = "room")
        public RoomDO room() {
            RoomDO roomdo= roomMapper.selectByPrimaryKey(1);
            LoggerUtil.info(logger, "出参roomdo:{0}", roomdo);//打印info级别的日志
            System.out.println(roomdo);
            return roomdo;
        }
    }

    第五步:运行打印日志

    会生成3个日志文件,这里只配置了3个文件,需要自行添加

    打印的日志信息:

  • 相关阅读:
    Java后台插件(工具包)
    LINQ系列:Linq to Object联接操作符
    LINQ系列:Linq to Object排序操作符
    LINQ系列:Linq to Object限制操作符
    LINQ系列:Linq to Object投影操作符
    LINQ系列:C#中与LINQ相关特性
    设计模式笔记:简单工厂模式(Simple Factory)
    数据访问模式:数据并发控制(Data Concurrency Control)
    数据访问模式:Identity Map(标识映射)模式
    设计模式笔记:开闭原则(OCP,The Open-Closed Principle)
  • 原文地址:https://www.cnblogs.com/zyf-yxm/p/9201202.html
Copyright © 2011-2022 走看看