spring boot使用 aop 处理方法的执行顺序

引入aop

<!-- 使用aop的依赖 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-aop</artifactId>
		</dependency>

创建切面处理类(可以做调用方法前校验session的处理,因为)

package com.jzy.aspect;

import com.jzy.util.PublicUtil;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;

/*
 * Created by zzb on 2017/10/23.
 *
 */
@Aspect
@Component
public class HttpAspect {
    private final  static Logger logger = LoggerFactory.getLogger(HttpAspect.class);
    /*拦截对对包下面的girlList方法(不管里面是什么参数)*/
//    @Before("execution(public * com.imooc.controller.EmailController.toIndex(..))")
    /*@Before("execution(public * com.imooc.controller.EmailController.*(..))")
    public void log(){
        System.out.println("6666666666");
    }

    @After("execution(public * com.imooc.controller.EmailController.*(..))")
    public void logAfter(){
        System.out.println("7777777777777777");
    }*/

    /*切点为controller包下面的所有类的所有方法*/
    @Pointcut("execution(public * com.jzy.controller.*.*(..))")
    public void log(){

    }

    /*进入方法之前执行*/
    @Before("log()")
    public void doBefore(JoinPoint joinPoint){
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        logger.info("@Before:"+PublicUtil.getCurrentTimestamp());
        /*logger.info("开始拦截");
        //url
        logger.info("url={}",request.getRequestURL());
        //method 类型(GET ,POST .....)
        logger.info("method={}",request.getMethod());
        //ip
        logger.info("ip={}",request.getRemoteAddr());
        //类方法
        logger.info("class_method={}",joinPoint.getSignature().getDeclaringTypeName() +"."+ joinPoint.getSignature().getName());

        //参数
        logger.info("args={}",joinPoint.getArgs());*/
    }

    /*方法执行之后执行*/
    @After("log()")
    public void doAfter(){
        logger.info("doAfter:"+PublicUtil.getCurrentTimestamp());
    }

    //controller中结果返回之后调用
    @AfterReturning(returning = "object",pointcut = "log()")
    public void doAfterReturning(Object object){
        logger.info("doAfterReturning:"+ PublicUtil.getCurrentTimestamp());
//        logger.info("response={}",object.toString());//拦截到void类型的方法也会报错
    }

}

controller方法

@RequestMapping(value = "/index",method = RequestMethod.GET)
    public String index(){
        logger.info("controller:"+PublicUtil.getCurrentTimestamp());
//        logger.info("邮件属性是:"+emailProperties.toString());
//        return new ModelAndView("user/index");
        emailRecordReposity.findOne(1);//执行一个数据库查询拉开时间间隔
        return "欢迎来到德莱联盟"+ PublicUtil.getCurrentTimestamp();
    }

最后附上一张验证结果图 (3和4由于执行的过程比较简单看不出来先后顺序,但其实@After是在Controller执行完返回结果之前执行的,总结下来,执行的顺序是@Before-》myMethod->@After->myMethod返回结果-》@AfterReturning




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值