软件编程
位置:首页>> 软件编程>> java编程>> spring-AOP 及 AOP获取request各项参数操作

spring-AOP 及 AOP获取request各项参数操作

作者:wkCaeser_  发布时间:2021-11-17 19:43:34 

标签:spring-AOP,AOP,request,参数

spring-AOP 及 AOP获取request各项参数

AOP称为面向切面编程,在程序开发中主要用来解决一些系统层面上的问题,比如日志,事务,权限等待。

一、AOP的基本概念

  • Aspect(切面):通常是一个类,里面可以定义切入点和通知

  • JointPoint(连接点):程序执行过程中明确的点,一般是方法的调用

  • Advice(通知):AOP在特定的切入点上执行的增强处理,有before,after,afterReturning,afterThrowing,around

  • Pointcut(切入点):就是带有通知的连接点,在程序中主要体现为书写切入点表达式

  • AOP代理:AOP框架创建的对象,代理就是目标对象的加强。Spring中的AOP代理可以使JDK * ,也可以是CGLIB代理,前者基于接口,后者基于子类

二、Spring AOP

Spring中的AOP代理还是离不开Spring的IOC容器,代理的生成,管理及其依赖关系都是由IOC容器负责,Spring默认使用JDK * ,在需要代理类而不是代理接口的时候,Spring会自动切换为使用CGLIB代理,不过现在的项目都是面向接口编程,所以JDK * 相对来说用的还是多一些。

三、基于注解的AOP配置方式

1.启用@AsjectJ支持

在spring配置中配置下面一句:


<aop:aspectj-autoproxy />

或者使用注解:


@EnableAspectJAutoProxy

2.通知类型介绍

(1) Before:在目标方法被调用之前做增强处理,@Before只需要指定切入点表达式即可

(2) AfterReturning:在目标方法正常完成后做增强,@AfterReturning除了指定切入点表达式后,还可以指定一个返回值形参名returning,代表目标方法的返回值

(3) AfterThrowing:主要用来处理程序中未处理的异常,@AfterThrowing除了指定切入点表达式后,还可以指定一个throwing的返回值形参名,可以通过该形参名

来访问目标方法中所抛出的异常对象

(4) After:在目标方法完成之后做增强,无论目标方法时候成功完成。@After可以指定一个切入点表达式

(5) Around:环绕通知,在目标方法完成前后做增强处理,环绕通知是最重要的通知类型,像事务,日志等都是环绕通知,注意编程中核心是一个ProceedingJoinPoint

3.通知执行的优先级

进入目标方法时,先织入Around,再织入Before,退出目标方法时,先织入Around,再织入AfterReturning,最后才织入After。

注意:Spring AOP的环绕通知会影响到AfterThrowing通知的运行,不要同时使用!同时使用也没啥意义。

4.切入点的定义和表达式

切入点表达式的定义算是整个AOP中的核心,有一套自己的规范

Spring AOP支持的切入点指示符:

execution:用来匹配执行方法的连接点


A:@Pointcut(“execution(* com.aijava.springcode.service….(…))”)

第一个表示匹配任意的方法返回值,…(两个点)表示零个或多个,上面的第一个…表示service包及其子包,第二个表示所有类,第三个*表示所有方法,第二个…表示

方法的任意参数个数


B:@Pointcut(“within(com.aijava.springcode.service.*)”)

within限定匹配方法的连接点,上面的就是表示匹配service包下的任意连接点


C:@Pointcut(“this(com.aijava.springcode.service.UserService)”)

this用来限定AOP代理必须是指定类型的实例,如上,指定了一个特定的实例,就是UserService


D:@Pointcut(“bean(userService)”)

bean也是非常常用的,bean可以指定IOC容器中的bean的名称

下面是一个使用AOP获取统计计算方法执行时间以及获取request请求参数等信息的log方法:


/**
* description:
* 统计请求执行时间
*
* @author wkGui
*/
@Component
@Aspect
public class ResExeTimeCounter {
   private static Logger logger = LoggerFactory.getLogger(ResExeTimeCounter.class);
   @Pointcut("execution(* com.wk.controller..*.*(..))")
   public void pointCut() {
   }
   @Around("pointCut()")
   public Object around(ProceedingJoinPoint pjp) throws Throwable {
       RequestAttributes ra = RequestContextHolder.getRequestAttributes();
       ServletRequestAttributes sra = (ServletRequestAttributes) ra;
       assert sra != null;
       HttpServletRequest request = sra.getRequest();
       String url = request.getRequestURL().toString();
       String method = request.getMethod();
       String queryString = request.getQueryString();
       long startTime = System.currentTimeMillis();
       logger.info("{url:{}, method:{}, queryString:{}}", url, method, queryString);
       Object rs;
       boolean successAble = false;
       JsonObject paramsJson = new JsonObject();
       try {
           Object[] params = pjp.getArgs();
           for (int i = 0; i < params.length; i++) {
               if (params[i] instanceof BindingResult
                       || params[i] instanceof HttpRequest
                       || params[i] instanceof HttpResponse){
                   continue;
               }
               paramsJson.addProperty("param-" + i, JsonUtil.toJsonWtihNullField(params[i]));
           }
           rs = pjp.proceed();
           successAble = true;
       } finally {
           logger.info("{url:{}, method:{}, success-able:{}, exe-time:{}, params:{}}", url, method, successAble, System.currentTimeMillis() - startTime, paramsJson);
       }
       return rs;
   }
}

SpringAOP获取request中所有参数,记录用户操作日志

今天搞了一个AOP的管理日志,蛋疼的很....

老规矩贴代码吧

spring-AOP 及 AOP获取request各项参数操作

首先除了aop的包以外需要这三个包。

自行度娘。

spring-AOP 及 AOP获取request各项参数操作

如果想切入controllers,请将这个代码写入你的mvc配置中,纠结了一上午切不进去就是这个原因.

spring-AOP 及 AOP获取request各项参数操作

method为你切入类的方法名

spring-AOP 及 AOP获取request各项参数操作

可以照这个打个模版出来,PS:无视注释哈,逼死强迫症

spring-AOP 及 AOP获取request各项参数操作

因为我的控制类里面只会有两个参数request和response ,所以我这里request就直接等于了下标为0,

下面的


 Enumeration parameter = request.getParameterNames();
 while(parameter.hasMoreElements()) {
 String a=(String) parameter.nextElement();
 System.out.println(request.getParameter(a));
 }

可以获取从页面上传过来的所有参数以及参数名,参数:request.getParameter(a),参数名:a

上面的代码放在aop中实测可以,但如果放在 * 中,实测会返回一个date,不知道什么鬼,get请求的话偶尔会正常。post一定不正常,aop中无问题

来源:https://blog.csdn.net/qq_36666651/article/details/81045064

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com