异常处理及日志log4j

上传人:xiao****1972 文档编号:84255885 上传时间:2019-03-03 格式:DOC 页数:10 大小:93.50KB
返回 下载 相关 举报
异常处理及日志log4j_第1页
第1页 / 共10页
异常处理及日志log4j_第2页
第2页 / 共10页
异常处理及日志log4j_第3页
第3页 / 共10页
异常处理及日志log4j_第4页
第4页 / 共10页
异常处理及日志log4j_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《异常处理及日志log4j》由会员分享,可在线阅读,更多相关《异常处理及日志log4j(10页珍藏版)》请在金锄头文库上搜索。

1、异常处理及日志log4j1.1 异常处理基本知识Java中异常处理程序中错误分类:语法错误、运行时错误、逻辑错误什么是异常:异常是指程序运行过程中出现的一些错误称为异常。Java 提供了一系列用于处理异常的类,所有异常类的父类:java.lang.Exception;能够处理所有的运行时异常。Java中常用的异常类:Throwable可以抛出的RuntimeException系统异常(如内存溢出、磁盘已满等),一般无法修复FormatException参数格式化异常(如将12.5转换成整数)IndexOutOfException数组下标越界异常NullPointerException空指针异常

2、(访问空对象)异常处理:为了提高程序运行的健壮性,在程序出现异常时需要处理,称异常捕捉。1. 捕捉异常,如何捕捉异常?捕捉异常使用trycatch语句块:语法:try /可能引发异常的程序代码catch( 异常类 ex ) 注意可以使用多个catch语句块 /处理异常的代码finally /最终执行代码(始终执行)示例:演示除数为0的异常捕捉Try/catch*/finally?Try/catch*Try/catch*/finally?Try/finally?2. 自定义异常、抛出异常在用户在输入数据违反逻辑约束的时候需要抛出异常信息时,可以采用自定义异常。(例如:年龄为负数)自定义异常Pub

3、lic class 类名extends ExceptionPublic 构造方法(string message):base(message)抛出异常throw 异常名; 示例:演示年龄无效异常(“年龄18-30之间”)声明某个方法可能抛出某种异常Public void test() throws AException,BException示例:演示年龄无效异常(“年龄18-30之间”)1.2 项目中的异常方式一、 异常处理的普通原则i. 把整个系统分为两大类异常:一类,业务异常,写自定义异常来代表;一类,程序异常,直接采用Exception(或者另外一个自定义异常)来代表。项目要定义一个根自定

4、义异常类,表示本项目中所有的异常; ii. 在业务层、持久层把两类异常都抛出(不能把异常吃掉了);iii. 在控制层捕捉异常,并分类处理(分类catch业务异常和系统异常,对业务异常,把异常信息取出,转发到提示页面显示给用户;对系统异常,用日志系统写入日志,便于以后维护解决Bug);iv. 定义一个通用的显示提示信息的视图(可用用Jsp或者JS窗口)实现。二、 显示错误的方式i. 直接在输入页面,显示错误优点:明确、详细,客户操作方便。缺点:工作量大。ii. 提供一个公共的错误显示页面(还可以用JS实现自动返回)优点:通用、简单、工作量小。缺点:客户操作不方便。升级:考虑用div层,覆盖到输入

5、页面上方,显示误消息(可以用图片、css做得很漂亮)。iii. 使用JS弹出式窗口显示错误消息,点击确定后自动返回输入页面优点:实现方便、客户使用方便。缺点:操作不方便、丑。1.3 Log4j1.3.1 概念(一) 背景(为什么)?每一个软件系统,都要记录错误日志.写错误日志有几种方式:1自己写一个写错误日志的类和方法。2 用Apache组织开发的log4j日志框架。(二) 是什么Log for java,是Apache组织开发的一个通用的日志框架。(三) Log4j的好处1、 通用:是一组普通的Java类,能够加入几乎所有的项目中。2、 强大:能够将日志按级别(Info、Debug、Warm

6、、Error、Fatal等)输出;输出日志到几乎所有的终端:控制台、文件、网络、数据库等。3、 方便:可以简单地修改配置文件,轻易由一个输出级别换成另外一种输出级别;可以轻易地由一种输出目的地换成另外一种输出目的地。(四) Log4j介绍一、概述Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地

7、进行配置,而不需要修改应用的代码。此外,通过Log4j其他语言接口,您可以在C、C+、.Net、PL/SQL程序中使用Log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将Log4j集成到J2EE、JINI甚至是SNMP应用中。二,使用前的准备。1、下载log4j 地址为:http:/jakarta.apache.org/log4j/docs/download.html. 2、你可能要用到的jar文件有: 如果需要将日志发送到邮箱,则需要javamail API,JAF API (the JavaBea

8、ns Activation Framework)下载地址: http:/ 如果需要jms的支持,则需要jms API 下载地址为:http:/ Log4j介绍Log4j由三个重要的组件构成:日志信息的优先级 priority,日志信息的输出目的地Appender,日志信息的输出格式(布局)layout。1、日志的优先级,从低到高,依次有:DEBUG,INFO,WARN,ERROR,分别用来指定这条日志信息的重要程度;如果定义了了输入的级别为INFO,则只有等于及高于这个级别的才进行处理,此时将输入INFO,WARN,ERROR。值得注意的是,级别中还有两个关键字,ALL:打印所有的日志,OFF

9、:关闭所有的日志输出。2、输出端 Appenderlog4j提供了以下几种常用的输出目的地:org.apache.log4j.ConsoleAppender,将日志信息输出到控制台org.apache.log4j.FileAppender,将日志信息输出到一个文件org.apache.log4j.DailyRollingFileAppender,将日志信息输出到一个,并且每天输出到一个新的日志文件,按照不同的配置可以定义每月一个日志文件,或者每周,每天,每小时,每分钟等输出一个新的日志文件。org.apache.log4j.RollingFileAppender,将日志信息输出到一个文件,通过

10、指定文件的的尺寸,当文件大小到达指定尺寸的时候会自动把文件改名,如名为example.log的文件会改名为example.log.1,同时产生一个新的example.log文件。如果新的文件再次达到指定尺寸,又会自动把文件改名为example.log.2,同时产生一个example.log文件。依此类推,直到example.log. MaxBackupIndex,MaxBackupIndex的值可在配置文件中定义。org.apache.log4j.WriterAppender,将日志信息以流格式发送到任意指定的地方。org.apache.log4j.jdbc.JDBCAppender,通过JD

11、BC把日志信息输出到数据库中。.SMTPAppender,将日志信息以邮件的方式发送到指定的邮箱。3、输出格式(布局)layout通过appender可以控制输出的目的地,而如果要控制输出的格式,就可通过log4j的layout组件来实现。通过配置文件定义一个appender的输出格式,Log4j提供的布局模式有以下几种:org.apache.log4j.ConsoleAppender,输出到控制台org.apache.log4j.HTMLLayout,以HTML表格形式布局org.apache.log4j.PatternLayout,可以灵活地指定布局模式org.apache.log4j.S

12、impleLayout,包含日志信息的级别和信息字符串值得一提的是org.apache.log4j.PatternLayout 以Pattern方式的布局,使用Pattern的方式来指定布局。pattern 的参数如下:ConversionPattern参数的格式含义格式名 含义%c 输出日志信息所属的类的全名%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%dyyy-MM-dd HH:mm:ss ,输出类似:2002-10-18- 22:10:28 ;比如 %dHH:mm:ss,SSS 或 %ddd MMM yyyy HH:mm:ss,SSS.格式可以

13、参考 java类 SimpleDateFormat,不过 按照此类的设置会影响速度。你可以选择更快的方式 %dISO8601,%dABSOLUTE, %dRELATIVE.或者使用log4j的ISO8601DateFormat, AbsoluteTimeDateFormat,RelativeTimeDateFormat 和 DateTimeDateFormat 方式.%f 输出日志信息所属的类的类名%l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行%m 输出代码中指定的信息,如log(message)中的message%M 输出日志信息中所发生的方法名。%n 输出一个回车

14、换行符,Windows平台为“rn”,Unix平台为“n”%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推%r 输出自应用启动到输出该日志信息所耗费的毫秒数%t 输出产生该日志事件的线程名1.3.2 使用(五) 使用1、 下载log4j的jar文件,复制到你的web-inf目录下2、 写配置文件log4j.properties,放到src目录下:#设置log4j两个重要的参数:输出级别(ERROR)、输出目的地(CONSOLE,DailyRolling)log4j.rootLogger=ERROR,FILElo

15、g4j.addivity.org.apache=true# 应用于控制台log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppenderlog4j.appender.Threshold=DEBUGlog4j.appender.CONSOLE.Target=System.outlog4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayoutlog4j.appender.CONSOLE.layout.ConversionPattern=framework %d - %c -%-4r %t %-5p %c

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号