java Logger 的使用与配置(2)

Logger所对应的属性文件在安装jdk目录下的jre/lib/logging.properties  (比如在我当前的机子里是C:\Program Files\Java\jre6\lib\logging.properties)
logging.properties文件中的      (logging.properties文件里面包含了Logger的配置信息,包括日志在哪儿输出,什么level的,等等)
handlers= java.util.logging.ConsoleHandler  将日志内容输出到控制台
handlers= java.util.logging.FileHandler     将日志文件输出到文件中
handlers= java.util.logging.ConsoleHandler,java.util.logging.FileHandler 将日志内容同时输出到控制台和文件中

# Limit the message that are printed on the console to INFO and above.
java.util.logging.ConsoleHandler.level = INFO   //日志输出级别

java.util.logging.FileHandler.pattern = %h/java%u.log  为生成的输出文件名称指定一个模式。
模式由包括以下特殊组件的字符串组成,则运行时要替换这些组件:

  • "/" 本地路径名分隔符
  • "%t" 系统临时目录
  • "%h" "user.home" 系统属性的值
  • "%g" 区分循环日志的生成号
  • "%u" 解决冲突的惟一号码
  • "%%" 转换为单个百分数符号"%"

如果未指定 "%g" 字段,并且文件计数大于 1,那么生成号将被添加到所生成文件名末尾的小数点后面。

java.util.logging.FileHandler.limit = 50000   限制文件的大小,以字节为单位
java.util.logging.FileHandler.count = 1       指定有多少输出文件参与循环(默认为 1)。
java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter      指定要使用的 Formatter 类的名称(默认为java.util.logging.XMLFormatter)。 另外一个是:java.util.logging.SimpleFormatter。XMLFormatter是以xml样式输出,SimpleFormatter是以普通样式输出。
java.util.logging.FileHandler.append 指定是否应该将 FileHandler 追加到任何现有文件上(默认为 false)。

以下是我在类中实现日志输出的一个例子

[java] view plaincopy

  1. import java.io.File;
  2. import java.io.IOException;
  3. import java.text.SimpleDateFormat;
  4. import java.util.Date;
  5. import java.util.logging.ConsoleHandler;
  6. import java.util.logging.FileHandler;
  7. import java.util.logging.Level;
  8. import java.util.logging.Logger;
  9. import java.util.logging.SimpleFormatter;
  10. /**
  11. * 日志输出到登陆系统用户所在的根目录的邮政储蓄日志的文件夹下,
  12. * 并且根据系统日期命名日志文件
  13. * @author wang
  14. *
  15. */
  16. public class LoggerUtil {
  17. /** 存放的文件夹 **/
  18. private static String file_name = "邮政储蓄日志";
  19. /**
  20. * 得到要记录的日志的路径及文件名称
  21. * @return
  22. */
  23. private static String getLogName() {
  24. StringBuffer logPath = new StringBuffer();
  25. logPath.append(System.getProperty("user.home"));
  26. logPath.append("\\"+file_name);
  27. File file = new File(logPath.toString());
  28. if (!file.exists())
  29. file.mkdir();
  30. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  31. logPath.append("\\"+sdf.format(new Date())+".log");
  32. return logPath.toString();
  33. }
  34. /**
  35. * 配置Logger对象输出日志文件路径
  36. * @param logger
  37. * @throws SecurityException
  38. * @throws IOException
  39. */
  40. public static void setLogingProperties(Logger logger) throws SecurityException, IOException {
  41. setLogingProperties(logger,Level.ALL);
  42. }
  43. /**
  44. * 配置Logger对象输出日志文件路径
  45. * @param logger
  46. * @param level 在日志文件中输出level级别以上的信息
  47. * @throws SecurityException
  48. * @throws IOException
  49. */
  50. public static void setLogingProperties(Logger logger,Level level) {
  51. FileHandler fh;
  52. try {
  53. fh = new FileHandler(getLogName(),true);
  54. logger.addHandler(fh);//日志输出文件
  55. //logger.setLevel(level);
  56. fh.setFormatter(new SimpleFormatter());//输出格式
  57. //logger.addHandler(new ConsoleHandler());//输出到控制台
  58. } catch (SecurityException e) {
  59. logger.log(Level.SEVERE, "安全性错误", e);
  60. } catch (IOException e) {
  61. logger.log(Level.SEVERE,"读取文件日志错误", e);
  62. }
  63. }
  64. public static void main(String [] args) {
  65. Logger logger = Logger.getLogger("sgg");
  66. try {
  67. LoggerUtil.setLogingProperties(logger);
  68. logger.log(Level.INFO, "ddddd");
  69. logger.log(Level.INFO, "eeeeee");
  70. logger.log(Level.INFO, "ffffff");
  71. logger.log(Level.INFO, "gggggg");
  72. logger.log(Level.INFO, "hhhhhh");
  73. } catch (SecurityException e) {
  74. // TODO Auto-generated catch block
  75. e.printStackTrace();
  76. } catch (IOException e) {
  77. // TODO Auto-generated catch block
  78. e.printStackTrace();
  79. }
  80. }
  81. }

注意:Logger logger = Logger.getLogger("sgg");  sgg只能出现一次,否则回重复输出值

java Logger 的使用与配置(2)

时间: 2024-10-15 15:04:04

java Logger 的使用与配置(2)的相关文章

两种“新型”的javaweb后门(jspx和Java Logger)

利用这个可以突破st2下   强制jsp跳转login.jsp 利用jspx解决jsp后缀被限制拿shell - Hack Blog | 黑客博客http://www.hackblog.cn/post/45.html 两种“新型”的javaweb后门(jspx和Java Logger) | HuGtion's Bloghttps://www.hugtion.com/?p=768 关于JavaWeb后门问题一直以来都比较少,而比较新奇的后门更少.在这里我分享两个我最近搞的比较有意思的JavaWeb

spring框架整合使用定时任务框架java quartz的示例代码配置

原创整理不易,转载请注明出处:spring框架整合使用定时任务框架java quartz的示例代码配置 代码下载地址:http://www.zuidaima.com/share/1775583461723136.htm 有时候我们的任务(Job)需要再某些任务完成之后才能进行:例如从旧的数据库批量导数据的时候:需要现将被其他数据依赖的数据导入新的数据库:然后再进行关系的导入..在这种情况下我们就可以使用Quartz的listener来做文章了. 首先我们写一个主任务的类,命名为MainJob:她

Java开发常用环境变量配置

1. JDK变量名:JAVA_HOME变量值:D:\Program Files\Java\jdk1.7.0_25(即JDK的安装路径)配置解析:方便引用.归一原则(%JAVA_HOME%),第三方软件约定. 变量名:Path(该变量名在系统变量中已经存在)变量值:%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin配置解析:使系统在任何路径下都可以识别javac,java命令. 变量名:classpath变量值:.;%JAVA_HOME%\lib;%JAVA_HOME%\lib

LINUX系统下Java和Scala的环境配置

LINUX系统下Java和Scala的环境配置 最近,笔者在研究一个有关“自然语言处理”的项目,在这个项目中,需要我们用Spark进行编程.而Spark内核是由Scala语言开发的,所以在使用Spark之前,我们必须配置好Scala,而Scala又是运行在JVM上的,所以在配置Scala之前,先要配置好JDK.下面是我个人的一些总结. 我是在Win7系统下开的虚拟机,虚拟机的系统是CentOS7,在创建虚拟机完成后,它会自带一个OpenJDK,我的版本是这样的: 但是因为最开始不了解这个情况,所

【Java】环境变量的配置

注意点 1.环境变量不能有空格,比如C:\Program Files 2.JAVA_HOME:D:\Java\jdk1.7.0_67------------->注意不能加;分号 [Java]环境变量的配置,布布扣,bubuko.com

java多环境下的配置

在项目开发过程中经常会有开发环境.测试环境.生产环境等,这些环境下的配置文件又各不相同.如何在不同环境下使用不同的配置是一个有意思的问题 常用的做法有 1.使用jndi通过tomcat不同的配置,这个需要在每一个tomcat下都进行配置,最恶心的是在eclipse下tomcat插件无法读取到jndi的信息. 2.还是通过配置tomcat的参数,读取不同环境下的配置,这种情况也有问题,eclipse下的tomcat插件也无法读取到,因为开发环境才会用到tomcat插件,所以读取不到可以默认为开发环

Spring装配bean(在java中进行显式配置)

1.简单介绍 Spring提供了三种装配机制: 1.在XML中进行显式配置: 2.在java中进行显式配置: 3.隐式的bean发现机制和自动装配. 其中,1和3项在项目中经常使用,而在java中进行显示配置方式很少使用.本文专门介绍第2种方式. 如果在项目中,我们需要将第三方库装配到spring中,这时候就没法使用隐式装配方式(没法在第三方库中加@Component等注解),这时候, 就需要在两种显式配置中选方法配置. 其中在java中进行显式配置方式是更好的方案,因为它更为强大.类型安全并且

java web 404错误页面配置

java web 404错误页面配置:注意红框的地方,在工程的web.xml文件里的最开头加入如下的内容便可,但是也有问题,针对以.action后缀名和.jsp后缀名不起作用, 因为后面配置了一些拦截器专门拦截.action和.jsp文件

Java环境的安装与配置

Java环境的安装与配置 环境:Java8,win10 推荐oracle官网oracle官网https://www.oracle.com/index.html下载JDK进行安装 选择自己需要的版本下载 3.打开安装包,完成安装 打开我的电脑-->属性-->高级系统设置-->环境变量 新建修改环境 变量名:PATH 变量值:C:\Program Files\Java\jdk1.8.0_111\bin (JDK安装的bin目录路径) 变量名:JAVA_HOME 变量值:C:\Program