• log4j/slf4j


    log4j的使用

    • 引入log4j.jar包
    <dependency>
    	<groupId>log4j</groupId>
    	<artifactId>log4j</artifactId>
    	<version>1.2.17</version>
    </dependency>
    
    • 配置log4j.properties
    log4j.rootLogger=INFO,Console,OneFile,errFile
    #输出到控制台
    log4j.appender.Console=org.apache.log4j.ConsoleAppender
    log4j.appender.Console.encoding=utf-8 
    log4j.appender.Console.Target=System.out
    log4j.appender.Console.layout=org.apache.log4j.PatternLayout
    log4j.appender.Console.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss,SSS}][%c]%m%n
    
    #输出到文件级别为info
    log4j.appender.OneFile=org.apache.log4j.RollingFileAppender 
    log4j.appender.OneFile.encoding=utf-8 
    log4j.appender.OneFile.File=../logs/test-map/info.log
    log4j.appender.OneFile.MaxFileSize=10MB
    log4j.appender.OneFile.MaxBackupIndex=50
    log4j.appender.OneFile.Threshold=INFO  ## 只输出INFO级别以上的日志!!!
    log4j.appender.OneFile.layout=org.apache.log4j.PatternLayout
    log4j.appender.OneFile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss,SSS}][%c]%m%n
    
    #输出到文件级别为error
    log4j.appender.errFile=org.apache.log4j.RollingFileAppender 
    log4j.appender.errFile.encoding=utf-8 
    log4j.appender.errFile.File=../logs/test-map/error.log
    log4j.appender.errFile.MaxFileSize=10MB
    log4j.appender.errFile.MaxBackupIndex=50
    log4j.appender.errFile.Threshold=ERROR   ## 只输出ERROR级别以上的日志!!!
    log4j.appender.errFile.layout=org.apache.log4j.PatternLayout
    log4j.appender.errFile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss,SSS}][%c]%m%n
    
    
    • 使用方法
    private static final Logger LOGGER = Logger.getLogger(Test.class);
    LOGGER.info("message");
    

    slf4j的使用

    • 引入slf4j.jar
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.25</version>
    </dependency>
    
    
    • 配置log4j.properties(通log4j)

    • 使用方法
      slf4j与log4j最大的区别在于,slf4j可以使用占位符,好处是可以防止字符串注入
      private static final Logger logger = LoggerFactory.getLogger(Test.class);

    slf4j整合log4j

    为什么要整合,我不知道

    • 引入maven依赖
    <dependency>  
        <groupId>org.slf4j</groupId>  
        <artifactId>slf4j-log4j12</artifactId>  
        <version>1.7.2</version>  
    </dependency>
    

    note:如果不用maven依赖,需要导入log4j.jar、slf4j.jar、slf4j-log4j.jar三个jar包

    • 配置log4j.properties(同上)

    • 可以使用log4j,也可以使用slf4j

    log4j.properties日志内容解析

    • 输入日志的级别level
      log4j.rootLogger=INFO,Console,OneFile,errFile中的info为总的输出日志的级别;后面几个参数为输出位置的标识
      日志级别有五级,越向下级别越低:
    FATAL      0  
    ERROR      3   为严重错误 主要是程序的错误
    WARN       4   为一般警告,比如session丢失
    INFO       6   为一般要显示的信息,比如登录登出
    DEBUG      7  为程序的调试信息
    
    • 输出日志的位置appender
      log4j.appender.Console=org.apache.log4j.ConsoleAppender
      日志输出的目的地有以下几种:
     org.apache.log4j.ConsoleAppender(控制台),
    org.apache.log4j.FileAppender(文件),
    org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
    org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
    org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
    
    • 输出日志的格式layout
    org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
    org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
    org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
    
    • 设置日志输出级别Threshold
      log4j.appender.OneFile.Threshold=INFO ## 只输出INFO级别以上的日志!!!

    • 日志信息格式ConversionPattern
      log4j.appender.OneFile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss,SSS}][%c]%m%n
      符号含义为:
      -X号: X信息输出时左对齐;
      %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,
      %d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
      %r: 输出自应用启动到输出该log信息耗费的毫秒数
      %c: 输出日志信息所属的类目,通常就是所在类的全名
      %t: 输出产生该日志事件的线程名
      %l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10)
      %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
      %%: 输出一个"%"字符
      %F: 输出日志消息产生时所在的文件名称
      %L: 输出代码中的行号
      %m: 输出代码中指定的消息,产生的日志具体信息
      %n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行
      Threshold=DEBUG:指定日志消息的输出最低层次。
      ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
      Target=System.err:默认情况下是:System.out,指定输出控制台
      FileAppender 选项
      Threshold=DEBUF:指定日志消息的输出最低层次。
      ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
      File=mylog.txt:指定消息输出到mylog.txt文件。
      Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
      RollingFileAppender 选项
      Threshold=DEBUG:指定日志消息的输出最低层次。
      ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
      File=mylog.txt:指定消息输出到mylog.txt文件。
      Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
      MaxFileSize=100KB: 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。
      MaxBackupIndex=2:指定可以产生的滚动文件的最大数。
      log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n

    spring中log4j.properties位置问题

    • 默认放在classpath路径下,即src/main/resources下

    • log4j.properties的路径改变,或者名称改变
      需要在web.xml中指定

    <context-param>
      	<param-name>log4jConfigLocation</param-name>
      	<param-value>classpath*:log4j.properties</param-value>
     </context-param>
    

    web容器启动加载顺序问题:

    引用博客家国之恋https://www.cnblogs.com/jiaguozhilian/p/5819032.html

    • 启动一个WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点:

    • 紧接着,容器创建一个ServletContext(上下文),这个WEB项目所有部分都将共享这个上下文.

    • 容器将转化为键值对,并交给ServletContext.

    • 容器创建中的类实例,即创建监听

    • 在监听中会有contextInitialized(ServletContextEvent args)初始化方法,在这个方法中获得ServletContext = ServletContextEvent.getServletContext();
      context-param的值 = ServletContext.getInitParameter("context-param的键");

    • 得到这个context-param的值之后,你就可以做一些操作了.注意,这个时候你的WEB项目还没有完全启动完成.这个动作会比所有的Servlet都要早.换句话说,这个时候,你对中的键值做的操作,将在你的WEB项目完全启动之前被执行.

    • 举例.你可能想在项目启动之前就打开数据库.
      那么这里就可以在中设置数据库的连接方式,在监听类中初始化数据库的连接.

    • 这个监听是自己写的一个类,除了初始化方法,它还有销毁方法.用于关闭应用前释放资源.比如说数据库连接的关闭.

      • 例1:
    <!-- 加载spring的配置文件 -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/applicationContext.xml,/WEB-INF/action-servlet.xml,/WEB-
    INF/jason-servlet.xml</param-value>
    </context-param>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    
    • 例2:自定义context-param,且自定义listener来获取这些信息
    <context-param>
        <param-name>urlrewrite</param-name>
        <param-value>false</param-value>
    </context-param>
    <context-param>
        <param-name>cluster</param-name>
        <param-value>false</param-value>
    </context-param>
    <context-param>
        <param-name>servletmapping</param-name>
        <param-value>*.bbscs</param-value>
    </context-param>
    <context-param>
        <param-name>poststoragemode</param-name>
        <param-value>1</param-value>
    </context-param>
    <listener>
        <listener-class>com.laoer.bbscs.web.servlet.SysListener</listener-class>
    </listener>
    public class SysListener extends HttpServlet implements ServletContextListener {
    private static final Log logger = LogFactory.getLog(SysListener.class);
    public void contextDestroyed(ServletContextEvent sce) {
       //用于在容器关闭时,操作
    }
    //用于在容器开启时,操作
    public void contextInitialized(ServletContextEvent sce) {
       String rootpath = sce.getServletContext().getRealPath("/");
       System.out.println("-------------rootPath:"+rootpath);
       if (rootpath != null) {
        rootpath = rootpath.replaceAll("\\", "/");
       } else {
        rootpath = "/";
       }
       if (!rootpath.endsWith("/")) {
        rootpath = rootpath + "/";
       }
       Constant.ROOTPATH = rootpath;
       logger.info("Application Run Path:" + rootpath);
       String urlrewrtie = sce.getServletContext().getInitParameter("urlrewrite");
       boolean burlrewrtie = false;
       if (urlrewrtie != null) {
        burlrewrtie = Boolean.parseBoolean(urlrewrtie);
       }
       Constant.USE_URL_REWRITE = burlrewrtie;
       logger.info("Use Urlrewrite:" + burlrewrtie);
       其它略之....
       }
    }
       /*最终输出
       -------------rootPath:D:	omcat_bbswebappsBBSCS_8_0_3
       2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    Application Run Path:D:/tomcat_bbs/webapps/BBSCS_8_0_3/
       2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    Use Urlrewrite:true
       2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    Use Cluster:false
       2009-06-09 21:51:46,526 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    SERVLET MAPPING:*.bbscs
       2009-06-09 21:51:46,573 [com.laoer.bbscs.web.servlet.SysListener]-[INFO]
    Post Storage Mode:1
       */
    

    context-param和init-param区别

    web.xml里面可以定义两种参数:

    • application范围内的参数,存放在servletcontext中,在web.xml中配置如下:
    <context-param>
               <param-name>context/param</param-name>
               <param-value>avalible during application</param-value>
    </context-param>
    
    • servlet范围内的参数,只能在servlet的init()方法中取得,在web.xml中配置如下:
    <servlet>
        <servlet-name>MainServlet</servlet-name>
        <servlet-class>com.wes.controller.MainServlet</servlet-class>
        <init-param>
           <param-name>param1</param-name>
           <param-value>avalible in servlet init()</param-value>
        </init-param>
        <load-on-startup>0</load-on-startup>
    </servlet>
    

    在servlet中可以通过代码分别取用:

    package com.wes.controller;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    public class MainServlet extends HttpServlet ...{
        public MainServlet() ...{
            super();
         }
        public void init() throws ServletException ...{
             System.out.println("下面的两个参数param1是在servlet中存放的");
             System.out.println(this.getInitParameter("param1"));
             System.out.println("下面的参数是存放在servletcontext中的");
            System.out.println(getServletContext().getInitParameter("context/param"));
          }
    }
    

    第一种参数在servlet里面可以通过getServletContext().getInitParameter("context/param")得到
    第二种参数只能在servlet的init()方法中通过this.getInitParameter("param1")取得.

  • 相关阅读:
    ThinkDev组件库 开篇
    使用 CodeIgniter 框架快速开发 PHP 应用(六)
    使用 CodeIgniter 框架快速开发 PHP 应用(五)
    jQuery EasyUI 的截图插件(imgAreaSelect)用法
    细说UI线程和Windows消息队列
    ASP.NET MVC2 异常处理机制中令人费解的HTTP 500错误
    从了解到深入——剖析WF4的数据流
    .NET 4.0中数组的新增功能
    成功就是把自己的特长发挥得淋漓尽致(更新)
    WPF4数据绑定应用之“创建具有多种显示效果的字串”
  • 原文地址:https://www.cnblogs.com/nwu-edu/p/9416577.html
Copyright © 2020-2023  润新知