zoukankan      html  css  js  c++  java
  • Spring AOP获取拦截方法的参数名称跟参数值

    Spring AOP获取拦截方法的参数名称跟参数值

    注意:这种方式需要JDK1.8版本支持


    开始:

    1.aop配置: <aop:aspectj-autoproxy expose-proxy="true" />

    • 注意该配置需要配置在spring mvc的配置文件中,因为需要拦截controller层方法
    • 或者在必须要配置在spring配置文件中的情况下,同时需要拦截controller层的方法,可以在spring配置文件中加入controller层的包扫描

    2.具体代码:

    
    import org.apache.commons.lang3.ArrayUtils;
    import org.aspectj.lang.ProceedingJoinPoint;
    import org.aspectj.lang.Signature;
    import org.aspectj.lang.annotation.Around;
    import org.aspectj.lang.annotation.Aspect;
    import org.aspectj.lang.reflect.MethodSignature;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    
    /**
     * 请求参数拦截校验
     */
    @Aspect
    public class AopParamVerify {
        private static Logger log = LoggerFactory.getLogger(AopParamVerify.class);
    
        @Around(value = "execution(* com.website.controller..*.*(..))")
        public Object invoke(ProceedingJoinPoint joinPoint) {
    
            /**
             * 时间戳校验,超过一分钟,拦截
             */
             //返回结果封装类
            HzlqswReqResult rst = new HzlqswReqResult();
            //1.这里获取到所有的参数值的数组
            Object[] args = joinPoint.getArgs();
            Signature signature = joinPoint.getSignature();
            MethodSignature methodSignature = (MethodSignature) signature;
            //2.最关键的一步:通过这获取到方法的所有参数名称的字符串数组
            String[] parameterNames = methodSignature.getParameterNames();
            try {
    	        //3.通过你需要获取的参数名称的下标获取到对应的值
                int timeStampIndex = ArrayUtils.indexOf(parameterNames, "timeStamp");
                if (timeStampIndex != -1) {
                    long timeStamp = (Long) args[timeStampIndex];
                    if (System.currentTimeMillis() - timeStamp > 60000) {
                        rst.setResultCode(rst.resultCode_hashCode_overdue);
                        rst.setReturnMsg("时间戳过期");
                        rst.setReturnObject("时间戳过期");
                        return rst;
                    }
                }
                return joinPoint.proceed();
            } catch (Throwable throwable) {
                log.error("时间戳校验异常");
                throwable.printStackTrace();
                rst.setResultCode(rst.resultCode_error);
                rst.setReturnMsg("AOP校验异常");
                rst.setReturnObject("AOP校验异常");
                return rst;
            }
        }
    }
    

    3.效果:

  • 相关阅读:
    兼容所有浏览器的CSS3圆角效果
    浏览器兼容 IE6、IE7、IE8、Firefox、Opera CSS hack区分
    分享30个优秀的网站导航设计案例
    解析如何改善和优化 Web 服务器性能
    分享40款效果非常漂亮的 HTML5 & CSS3 网站模板,模板免费下载
    分享20个非常有创意的蓝色风格网页作品触发你的设计灵感
    分享20个效果非常绚丽的 CSS3 特性应用演示
    推荐12个优秀的 HTML5 网站设计案例欣赏
    网站设计风格及色彩搭配技巧
    舞动你的文字,巧用CSS中marquee属性
  • 原文地址:https://www.cnblogs.com/wing7319/p/9592184.html
Copyright © 2011-2022 走看看