SpringMVC使用AOP记录日志

本文介绍了如何在SpringMVC中利用AOP进行日志记录,包括创建AOP切面、在SpringMVC配置文件中开启AOP自定义代理的步骤,并特别提醒了两点注意事项:AOP配置应放在特定配置文件中,以及环绕通知方法必须返回执行结果以确保视图正常响应。
摘要由CSDN通过智能技术生成

欢迎访问我的个人博客:guqing’s blog

创建AOP

@Aspect
@Component
public class LoggerAop {
	//本地日志记录对象    
    private  static  final Logger logger = LoggerFactory.getLogger(LoggerAop.class);
    
    //controller切点
	@Pointcut("execution(* xyz.guqing.taotao.manage.controller.*.*(..))")
	public void pointCut(){}
	
	
	@Around(value="pointCut()")
    public Object doAroundAdvice(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
		//获取request对象
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
       
        //还可以使用request获取session中的用户名并记录到日志
        
        //获取请求的ip
        String ip = request.getRemoteAddr();
        
        //获取请求方法全限定名
        String methodName = proceedingJoinPoint.getTarget().getClass().getName() + "." + proceedingJoinPoint.getSignature().getName();
        
        //获取方法执行返回值
        Object returningValue = proceedingJoinPoint.proceed();
        
        //方法参数
        String params = JSONArray.toJSONString(proceedingJoinPoint.getArgs());
        
        //返回值转为json数组
        String returnJsonValue = JSONArray.toJSONString(returningValue);
        
        logger.info("请求ip地址:{},请求方法全名:{},请求参数:{},返回值:{}", ip, methodName, params, returnJsonValue);
        
        //对于环绕方法必须接收方法执行后的结果并返回,否则会导致视图获取不到返回值,或者直接就找不到视图
        return returningValue;
    }
	
	/**
	 * @Description: 当方法执行抛出异常时执行   
	 * @param: @param joinPoint
	 * @param: @param e
	 * @param: @throws Throwable 异常
	 * @return: void      
	 * @throws
	 */
	@AfterThrowing(value="pointCut()",throwing="e")
	public void doAfterThrowing(JoinPoint joinPoint,Throwable e) throws Throwable {
		//获取request对象
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        
        //获取请求的ip
        String ip = request.getRemoteAddr();
        
		//异常方法
		String methodName = joinPoint.getTarget().getClass().getName() + "." + joinPoint.getSignature().getName();
		
		//异常信息
		String errorInfo = e.getMessage();
		
		//请求参数
		String params = JSONArray.toJSONString(joinPoint.getArgs());
		
		logger.error("异常请求ip:{},异常方法全名:{},异常信息:{},请求参数:{}",ip,methodName,errorInfo,params);
	}
}

在Springmvc的配置文件中开启AOP自定代理

<!-- 开启aop自动代理 -->
<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>

注意:

1. 不要将AOP自动代理的配置添加到applicationContext.xml中,要添加在springmvc的配置文件中,否则AOP切面不执行。
2. 切记环绕方法,要将方法执行结果返回,否则即时路径是对的会找不到视图,或者执行后视图得不到响应结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值