log4j+AOP 记录错误日志信息到文件中
AOP 采用异常通知切入,把指定包的异常记录到日志文件。
先看log4j.properties ,控制台输出的是普通信息, 文件输出的是异常信息。
log4j.rootLogger=DEBUG, Console
log4j.logger.com.java1234.aop=error,appender1 #file E:/temp/test.txt E\:\\temp\\test.txt
log4j.appender.appender1=org.apache.log4j.FileAppender
log4j.appender.appender1.File=E:/temp/test.txt
log4j.appender.appender1.layout=org.apache.log4j.SimpleLayout #Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
spring 配置文件中要记得加入AOP扫描注解,并且把需要切入的类交给spring控制。
<!-- 自动扫描 -->
<context:component-scan base-package="com.java1234" /> <!-- AOP XML配置 -->
<!-- <bean id="helloBean"
class="com.java1234.aop.HelloAspectBean">
</bean>
<aop:config>
<aop:pointcut id="servicePoint"
expression="within(com.java1234.service.impl.*)"/>
<aop:aspect ref="helloBean">
<aop:before method="helloMethod"
pointcut-ref="servicePoint"/>
</aop:aspect>
</aop:config> --> <!-- AOP注解配置 -->
<!-- 开启AOP注解配置@Aspect,@Pointcut,@Before等 -->
<aop:aspectj-autoproxy proxy-target-class="true"/>
applicationContext.xml
重点来了,异常通知的切入方法怎么写。
import org.apache.log4j.Logger;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component; @Component
@Aspect//指定为方面
public class HandlerExceptionBean {
Logger logger =
Logger.getLogger(HandlerExceptionBean.class); //采用异常通知切入,目标Service抛出异常给ex参数
@AfterThrowing(throwing="ex",pointcut="within(com.java1234.service.impl.*)")
public void exceptionMethod(Exception ex){
//将ex信息写入日志文件error.log
logger.error("发生异常,异常类型:"+ex);
StackTraceElement[] st = ex.getStackTrace();
StringBuilder msg = new StringBuilder();
for(StackTraceElement s : st){
msg.append(s);
msg.append("\n");
}
logger.error(msg);
}
}
HandlerExceptionBean
如果不用log4j,也可以只用AOP把异常写到指定文件,参考下面代码。
@Component
@Aspect//指定为方面
public class HandlerExceptionBean { //采用异常通知切入,目标Service抛出异常给ex参数@AfterThrowing(throwing="ex",pointcut="within(org.tarena.note.web.controller..*)")
public void exceptionMethod(Exception ex){ // 将ex信息写入日志文件error.log
String file="E:\\temp\\error.log";
try {
FileWriter out = new FileWriter(file,true);
PrintWriter pw=new PrintWriter(out);
ex.printStackTrace(pw);
pw.flush();
pw.close();
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
log4j+AOP 记录错误日志信息到文件中的更多相关文章
- Log4j分级别保存日志到单个文件中,并记录IP和用户信息
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration S ...
- C#写入日志信息到文件中
为了在服务器上运行程序及时的跟踪出错的地方,可以在必要的地方加入写日志的程序. string folder = string.Format(@"D:\\{0}\\{1}", Dat ...
- ASP.NET MVC中错误日志信息记录
MVC中有一个处理异常的过滤器 HandleErrorAttribute 1.新建一个类继承自 HandleErrorAttribute,然后重写OnException这个方法 public clas ...
- 【转】ASP.NET MVC中错误日志信息记录
MVC中有一个处理异常的过滤器 HandleErrorAttribute 1.新建一个类继承自 HandleErrorAttribute,然后重写OnException这个方法 public clas ...
- WebForm应用log4net记录错误日志——使用线程列队写入
我的项目结构如下图: 日志帮助类库需要log4net包:工具—NuGet包管理器—管理解决方案NuGet程序包 线程日志帮助类 FlashLogger.cs 代码 using System; usin ...
- Log4j按级别输出日志到不同文件配置
1.自定义LogFileAppender类,继承DailyRollingFileAppender,实现Log4j按级别输出日志到不同文件. package com.liying.mango.commo ...
- ASP.NET记录错误日志的方式
程序记录错误日志是一种看起来对一般用户没什么作用,但对程序开发者用处很大的东西,它能查出错误或异常的程序马迹.那么,常用的记录错误日志的方式有哪些呢? 大多数情况下使用的是 1.直接记录为txt/xm ...
- C#添加错误日志信息
错误日志是软件用来记录运行时出错信息的文本文件.编程人员和维护人员等可以利用错误日志对系统进行调试和维护. 系统日志 系统日志包含了由Windows系统组件记录的事件.例如,在启动期间装入驱动程序或其 ...
- 【MySQL】关于MySQL错误日志信息的收集
为方便维护MySQL,写了个脚本用以提供收集错误信息的接口.这些错误信息来自与MySQL错误日志,而 通过grep mysql可以获取error-log的路径. #!/usr/bin/env pyth ...
随机推荐
- <div>里用display:block有用么?
对所有的块元素都没有意义,块元素的dispaly属性默认值为block,没必要再显式定义--除非你之前对块元素的display属性重新定义过. =========================== ...
- 随机森林(Random Forests)
简单地看了一些入门的资料. 随机森林似乎和CART有些联系. 随机森林的算法步骤: 1. 利用自助法(Bootstrap)从原始训练集中生成k个自助样本集,每个自助样本集是每棵分类树的全部训练数据.自 ...
- 深入理解JavaScript系列(30):设计模式之外观模式
介绍 外观模式(Facade)为子系统中的一组接口提供了一个一致的界面,此模块定义了一个高层接口,这个接口值得这一子系统更加容易使用. 正文 外观模式不仅简化类中的接口,而且对接口与调用者也进行了解耦 ...
- Google Kickstart在线测试规则以及注意事项
谷歌招聘在如火如荼的进行中,进谷歌都需要经过谷歌kickstart在线测试,然后过了之后还有五轮的面试- -.好吧毕竟你待遇高,你强你有理.. 下面介绍一下进谷歌的第一关google kickstar ...
- c++ sizeof对象大小整理
1. sizeof 是运算符,而不是函数. 2. 当sizeof 的对象是表达式时,求的大小是表达式返回值的类型大小,但并不计算表达式的值,比如: ; ; cout << sizeof(c ...
- js简单时分秒倒计时
效果: javascript: <script type="text/javascript"> function countTime() { //获取当前时间 var ...
- LI居中
在用UL-LI时,有适合需要将Li里面的内容居中显示:方法有两种:(推荐)1.设置LI的display为inline(规定应该从父元素继承 display 属性的值),为LI设置长度,设置text-a ...
- javascript: iframe switchSysBar 左欄打開關閉,兼容各瀏覽器操作
<html> <head> <meta content="text/html; charset=utf-8" http-equiv="Con ...
- 【数据库】3.0 MySQL入门学习(三)——Windows系统环境下MySQL安装
1.0 我的操作系统是window10 专业版 64位.,不过至少windows7以上系统都是一样的. 关于MySQL如何下载,请参考博文: [数据库]2.0 如何获得MySQL以及MySQL安装 h ...
- Number()转换规则
转换规则: Number(): 1)如果是Boolean值,true和false将分别转换为1和0. 2)如果是数字值,只是简单的传入和返回. 3)如果是null值,返回0. 4)如果是undefin ...