spring-mvc Interceptor

同时拦截多个方法,拦截器中取被拦截方法的信息,比如方法名、参数等。

由于在一个项目中拦截器的使用必不可少,我在此整理一下用法:

1、before :在方法执行前拦截

    //updateUser前拦截
    @Before("execution(* com.ll.test.manager.UserManager.updateUser(..)) && args(token, user,..)")
    public void beforeUpdateUser(String token, UserEntity user) throws Throwable{
        //可以在这里执行相应的操作  比如更改参数
        System.out.println("beforeUpdateUser ====user == "+ JSON.toJSONString(user));
    }

2、After:在方法执行后拦截

    //updateUser后拦截
    @After("execution(* com.ll.test.manager.UserManager.updateUser(..)) && args(token, user,..)")
    public void afterUpdateUser(String token, UserEntity user) throws Throwable{
        System.out.println("afterUpdateUser ====user == "+ JSON.toJSONString(user));
        //可以在这里执行相应的操作  比如更新session等
    }

3、Around:可以在方法执行前做相应的操作也可以在方法执行后做相应的操作,这个尤其重要,因为当拦截多个方法时,需要取当前拦截的方法的信息时只有Around可以实现。示例:

    //拦截多个方法  并且取得拦截的具体某个方法的信息
    @Around("execution(* com.ll.test.manager.Analysis*.search*(..)) or execution(* com.ll.test.manager.Body*.search*(..)) or execution(* com.ll.test.manager.Data*.search*(..)) or execution(* com.ll.test.manager.Find*.search*(..))")
    public Object aroundSearchInformation(ProceedingJoinPoint proceedingJoinPoint) throws Throwable{
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date start = new Date();
        Signature sig = proceedingJoinPoint.getSignature();
        MethodSignature msig = null;
        if (!(sig instanceof MethodSignature)) {
            throw new IllegalArgumentException("该注解只能用于方法");
        }
        msig = (MethodSignature) sig;
        Object target = proceedingJoinPoint.getTarget();
        Method currentMethod = target.getClass().getMethod(msig.getName(), msig.getParameterTypes());
        System.out.println("////////////"+currentMethod.getName()+"///////start/////// "+sdf.format(start));
        //放行  这里执行被拦截的方法
        Object result = proceedingJoinPoint.proceed();
        Date end = new Date();
        System.out.println("////////////"+currentMethod.getName()+"////////end////// "+sdf.format(end));
        return result;
    }

猜你喜欢

转载自blog.csdn.net/liulinsmile/article/details/78896325