SpringAOP日志配置

配置文件配置

配置spring-mvc.xml

<aop:config proxy-target-class="true" />

<bean id="logInterceptor" class="com.sjzxywlkj.cplife.log.LogInterceptor" />

<!-- 使用xml配置aop -->

<!-- 强制使用cglib代理,如果不设置,将默认使用jdk的代理,但是jdk的代理是基于接口的 -->

<aop:config>

<!--定义切面 -->

<aop:aspect id="logAspect" ref="logInterceptor">

<!-- 定义切入点 (配置在com.sjzxywlkj.cplife.controller下所有的类在调用之前都会被拦截) -->

<aop:pointcut expression="execution(* com.sjzxywlkj.cplife.controller.*.*(..))"

id="logPointCut" />

<!--方法执行之前被调用执行的 -->

<aop:before method="before" pointcut-ref="logPointCut" /><!--一个切入点的引用 -->

<aop:after method="after" pointcut-ref="logPointCut" /><!--一个切入点的引用 -->

</aop:aspect>

</aop:config>

日志处理类

package com.sjzxywlkj.cplife.log;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

public class LogInterceptor {

private final Logger logger = LoggerFactory.getLogger(LogInterceptor.class);

// private static Logger logger =LoggerFactory.getLogger(LogInterceptor.class);

public void before() {

logger.info("login start!");

logger.debug("lllllllllllllllllllllll");

// System.out.println("qqqqqqqqqqqqqqqqqqqqq");

}

public void after() {

logger.info("login end!");

logger.debug("aaaaaaaaaaaaaaaaaaaaaaaaa");

// System.out.println("wwwwwwwwwwwwwwwwwwwwwwwwwww");

}

}

log4j.properties日志文件配置

### 设置###

### 日志相应级别debug,输出位置 d,e

log4j.rootLogger = debug,D,E

### 输出DEBUG 级别以上的日志到=E://logs/log.log ###

log4j.appender.D = org.apache.log4j.DailyRollingFileAppender

log4j.appender.D.File = ${webapp.root}/WEB-INF/logs/log.log

log4j.appender.D.Append = true

log4j.appender.D.Threshold = DEBUG

log4j.appender.D.layout = org.apache.log4j.PatternLayout

log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 输出ERROR 级别以上的日志到=E://logs/error.log ###

log4j.appender.E = org.apache.log4j.DailyRollingFileAppender

log4j.appender.E.File =${webapp.root}/WEB-INF/logs/error.log

log4j.appender.E.Append = true

log4j.appender.E.Threshold = ERROR

log4j.appender.E.layout = org.apache.log4j.PatternLayout

log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ]  %m%n

web.xml配置日志

<context-param>

<param-name>log4jConfigLocation</param-name>

<param-value>classpath:resources/log4j.properties</param-value>

</context-param>

<listener>

<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>

</listener>

注解文件配置

spring-mvc.xml文件配置

方法一

//扫描aop日志处理类

<context:component-scan base-package="com.sjzxywlkj.cplife.log" />

//开启aop

<aop:aspectj-autoproxy proxy-target-class="true" />

方法二

<bean id="logInterceptor" class="com.sjzxywlkj.cplife.log.LogInterceptor"></bean>

<aop:aspectj-autoproxy proxy-target-class="true"/>

日志切面类

package com.sjzxywlkj.cplife.log;

import org.aspectj.lang.annotation.After;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

@Aspect

@Component

public class LogInterceptor {

private final Logger logger = LoggerFactory.getLogger(LogInterceptor.class);

@Before(value = "execution(* com.sjzxywlkj.cplife.controller.*.*(..))")

public void before() {

logger.info("login start!");

System.out.println("lllllllllllllllllllll");

}

@After(value = "execution(* com.sjzxywlkj.cplife.controller.*.*(..))")

public void after() {

logger.info("login end!");

System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaa");

}

}

基于自定义注解

配置文件设置

<context:component-scan base-package="com.sjzxywlkj.cplife.log"></context:component-scan>

<context:component-scan base-package="com.sjzxywlkj.cplife.annotation"></context:component-scan>

<aop:aspectj-autoproxy proxy-target-class="true">

</aop:aspectj-autoproxy>

l   自定义注解

package com.sjzxywlkj.cplife.annotation;

import java.lang.annotation.Documented;

import java.lang.annotation.ElementType;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

@Target(ElementType.METHOD)

@Retention(RetentionPolicy.RUNTIME)

@Documented

public @interface Log {

String oper() default "";

}

l   日志切面类

package com.sjzxywlkj.cplife.log;

import java.lang.reflect.Method;

import org.aspectj.lang.JoinPoint;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.aspectj.lang.annotation.Pointcut;

import org.aspectj.lang.reflect.MethodSignature;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

import com.sjzxywlkj.cplife.annotation.Log;

@Aspect

@Component

public class LogInterceptor {

private final Logger logger = LoggerFactory.getLogger(LogInterceptor.class);

@Pointcut("@annotation(com.sjzxywlkj.cplife.annotation.Log)")

public void controllerAspect() {

}

@Before("controllerAspect()")

public void before(JoinPoint joinPoint) {

logger.info(getOper(joinPoint));

}

private String getOper(JoinPoint joinPoint) {

MethodSignature methodName = (MethodSignature) joinPoint.getSignature();

Method method = methodName.getMethod();

return method.getAnnotation(Log.class).oper();

}

}

l   Controller注入

@Controller

@RequestMapping("/user")

public class UserController {

@Autowired

private IUserService uService;

// 用户登录

@RequestMapping(value = "/login", method = RequestMethod.GET)

@ResponseBody

@Log(oper="user login")

public String login(){

return null;

}

SpringAOP日志配置的更多相关文章

  1. Spring2.5那些事之基于AOP的方法级注解式日志配置

    在日常开发中经常需要在代码中加入一些记录用户操作日志的log语句,比如谁在什么时间做了什么操作,等等. 把这些对于开发人员开说无关痛痒的代码写死在业务方法中实在不是一件很舒服的事情,于是AOP应运而生 ...

  2. django 1.8 日志配置

    django 1.8 日志配置 以下为setings配置logging代码片段 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(_ ...

  3. nginx日志配置

    nginx日志配置 http://www.ttlsa.com/linux/the-nginx-log-configuration/ 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如 ...

  4. 日志配置logback

    在选择项目日志框架时,发现log4j的作者开发了新的日志框架,据说性能提高不少,那就选它了,不过,除了配置上有点不习惯外,最重要的一点 ,打印线程号这个功能依然没有(打印线程名这个东西是在是个鸡肋). ...

  5. 服务器是windows时tomcat无法打印所有日志配置修改

    Tomcat运行仅一天磁盘空间突然就增加了很多,发现是日志文件太大了,修改tomcat的日志配置即可. 查看目录所占空间大小: ? 1 [root@XXX webapps]du -sh 清理方法: ? ...

  6. [译]Stairway to Integration Services Level 12 - 高级日志配置

    介绍 本文中,我们将结合之前学习的时间冒泡,日志记录,以及复制模型.建立一个自定义的SSIS包日志模型. SSIS Task事件回顾    Reviewing SSIS Task Events 在做实 ...

  7. [译]Stairway to Integration Services Level 11 - 日志配置

    介绍 在前一个章节我们讨论了事先行为,分享了如何操作默认的行为和时间冒泡,并且介绍了父子模型. 本文中,我们会配置SSIS日志. 进行简单及高级日志配置,存储,和检索的实验.并且生成自定义日志信息. ...

  8. Nginx日志配置及日志切割

    日志配置 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如access_log.log_format.open_log_file_cache.log_not_found.log_s ...

  9. SpringBoot之简单日志配置

    我的目的指定一个文件夹输出:(不采用指定文件的原因是一个文件的大小时间长了会很大,不利于处理) logging: level: root: INFO org.sselab: controller: I ...

随机推荐

  1. java实验四《Android程序设计》实验报告

    一.实验报告封面 课程:Java程序设计 班级:1653班 姓名:张士洋 学号:20165308 指导教师:娄嘉鹏 实验日期:2018年5月14日 实验时间:13:45 - 15:25 实验序号:08 ...

  2. Guava 3: 集合Collections

    一.引子 Guava 对JDK集合的拓展,是最成熟且最受欢迎的部分.本文属于Guava的核心,需要仔细看. 二.Guava 集合 2.1 Immutable Collections不可变集合 1.作用 ...

  3. eclipse 安装配置

    https://blog.csdn.net/jklinux/article/details/77861450 JAVA环境配置 https://jingyan.baidu.com/article/db ...

  4. ubuntu彻底卸载opencv

    说正事之前,先啰嗦两句背景,算是拿个小本本记下了. 我本打算下载opencv2.4.在github上找到源码,在Branch处选择切换到2.4,然后复制URL,在terminal里面使用git clo ...

  5. 红米note3发热严重,小米真垃圾!

    红米note3全网通高配版,高通处理器骁龙650(MSM8956),夏天在有空调的房间,上网几分钟手机发烫,真垃圾! ROM已经是官方最新稳定版.MIUI8.5.2.0(LHNCNED) 红米NOTE ...

  6. Java中字段、属性、成员变量、局部变量、实例变量、静态变量、类变量、常量

    首先看个例子: package zm.demo; public class Demo { private int Id;//成员变量(字段).实例变量(表示该Id变量既属于成员变量又属于实例变量) p ...

  7. 在HTML中显示base64 img 图片

    base64的图片可以直接显示在网页上面 <img src=“data:image/png;base64,******************************************** ...

  8. 【学习】基础知识:数组和矢量计量【Numpy】

    Numpy是高性能科学计算和数据分析的基础包.功能如下: ndarray 一个具有矢量算法运算和复杂广播能力的快速且节省空间的多维数组 用于对整组数据进行快速运算的标准数学函数(无需编写循环) 用于读 ...

  9. Mybatis中DAO层接口没有写实现类,Mapper中的方法和DAO接口方法是怎么绑定到一起的,其内部是怎么实现的

    其实也就是通过接口名与mapper的id绑定在一起(即相同),通过SQL去写实现类,返回数据.

  10. 编织织物的knit course direction and knit wale direction

    来自:http://www.definetextile.com/2013/04/course-wale.html