[TOC]
## **日志级别**
在前面记录日志的时候有提到日志的级别,实际上Logger的级别有:
| SEVERE | 严重 |
| --- | --- |
| WARNING | 警告 |
| INFO | 信息 |
| CONFIG | 配置 |
| FINE | 良好 |
| FINER | 较好 |
| FINEST | 最好 |
:-: ![](https://img.kancloud.cn/0c/86/0c86fc4f896c2bda4a821e8e8e3938ac_966x311.png)
## **log4j案例一**
~~~java
package day01logger;
import org.apache.log4j.Logger;
public class day01logger01{
//Logger.getLogger(Tester.class),根据log4j.properties文件的配置去创建一个Tester类(当前类的字节码对象)的日志对象
private static Logger logger = Logger.getLogger(day01logger01.class);
public static void main(String[] args) {
//logger.error(Object message,Throwable t);
loggertest();
}
public static void loggertest(){
logger.error("这是error信息");
logger.warn("这是warn信息");
logger.info("这是info信息");
logger.debug("这是debug信息");
}
}
~~~
<br>
## **配置文件**
```
#根logger设置###debug表示日志的级别,console表示控制台,file表示文件位置
log4j.rootLogger = INFO,console,file
# 输出信息到控制台###
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.Threshold = DEBUG
log4j.appender.console.layout.ConversionPattern = [%p] %d{yyyy-MM-dd HH:mm:ss} method: %l----%m%n
#输出INFO 级别以上的日志文件设置###
#每天产生一个日志文件###
log4j.appender.file = org.apache.log4j.DailyRollingFileAppender
#将日志输出到指定位置,下面输出到的是src下的log文件夹下,保存为web.log###
log4j.appender.file.File = Logs/log/web.log
log4j.appender.file.Append = true
log4j.appender.file.Threshold = warn
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} method: %l - [ %p ]----%m%n
```
打印的参数设置示例:
~~~
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} method: %l - [ %p ]----%m%n
~~~
* %m 输出代码中指定的消息
* %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
* %r 输出自应用启动到输出该log信息耗费的毫秒数
* %c 输出所属的类目,通常就是所在类的全名
* %t 输出产生该日志事件的线程名
* %n 输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n”
* %d 输出日志时间点的日期或时间。默认格式为ISO8601,也可以在其后指定格式。比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日 22:10:28, 921
* %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数
- Java自动化测试
- 第一章:Java:基础内容
- 1.1:Java:Hello Word
- 1.2:Java:热身
- 1.3:Java:注释
- 1.4:Java:标识符
- 1.5:Java:常量
- 1.6:Java:基本数据类型
- 1.7:Java:引用类型
- 1.8:Java:String类
- 第二章:Java:运算符
- 2.1:Java:算数运算符
- 2.2:Java:关系运算符
- 2.3:Java:逻辑运算
- 2.4:Java:赋值运算符
- 2.5;Java:三元运算符
- 2.6:Java:位运算符
- 第三章:Java:循环控制语句
- 3.1:Java:for循环
- 3.2:Java:while循环
- 3.3:Java:switch
- 3.4:Java:if else
- 3.5:Java:练习题
- 第四章:Java:函数与全局/局部变量
- 4.1:Java:局部变量
- 4.2:Java:全局变量
- 第五章:Java:方法
- 5.1:Java:初识方法
- 5.2:Java:方法调用
- 5.3:Java:方法重载
- 5.4:Java:构造方法
- 5.5:Java:方法的注意事项
- 第六章:Java:面向对象
- 6.1:Java:小案例
- 6.2:Java:this 关键字
- 6.3:Java:super 关键字
- 6.4:Java:static 关键字
- 6.5:Java:final关键字
- 6.6:Java:instanceof 运算符
- 6.7:Java:面向对象之封装
- 6.8:Java:面向对象之继承
- 6.9:Java:面向对象之多态
- 第七章:Java:面向对象高级进阶
- 7.1:Java:抽象类
- 7.2:Java:Java中String类
- 7.3:Java:interface接口
- 7.4:Java:ArrayList
- 7.5:Java:HashSet
- 7.6:Java:HashMap
- 7.7:Java:反射(reflection)
- 第八章:Java:日志以及异常捕获
- 8.1:Java:log4j
- 8.2:Java:异常初识基础
- 8.3:Java:未被捕获的异常
- 8.4:Java:try和catch的使用
- 8.5:Java:多重catch语句的使用
- 8.6:Java:throws/throw 关键字
- 8.7:Java:finally关键字
- 8.8:Java:自定义异常
- 第九章:Java:xml and IO
- 9.1:Java:IO基本概念
- 9.2:java:properties
- 9.3:Java:xml基本介绍
- 9.4:Java:xml操作实例
- 第十章:Java:JDBC编程
- 10.1:Java:JDBC介绍
- 10.2:Java:JDBC查询
- 10.3:Java:JDBC插入
- 10.4:Java:Batch
- 10.5:Java:JDBC连接池
- 第十一章:Java:TestNG
- 11.1:java:TestNG简介
- 11.2:Java:TestNG小实例
- 11.3:Java:TestNG.xml文件配置
- 11.4:Java:TestNG基本注解
- 11.5:Java:TestNG注解代码
- 11.6:Java:TestNG预期异常
- 11.7:Java:TestNG忽略测试
- 11.8:Java:TestNG超时测试
- 11.9:Java:TestNG分组测试