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

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

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

标签:spring-AOP,AOP,request,参数
0
投稿

猜你喜欢

  • java学习DongTai被动型IAST工具部署过程

    2023-06-21 09:43:03
  • spring boot 集成 shiro 自定义密码验证 自定义freemarker标签根据权限渲染不同页面(推荐

    2023-07-28 17:39:16
  • Spring Boot从Controller层进行单元测试的实现

    2023-07-21 03:07:10
  • spring boot 打包jar jar没有主目录清单问题的完美解决方法

    2021-08-28 16:07:39
  • 在Java内存模型中测试并发程序代码

    2023-11-24 20:37:55
  • Java使用Tess4J实现图像识别方式

    2022-10-07 19:24:11
  • java日期格式化SimpleDateFormat的使用详解

    2023-08-25 03:22:15
  • C#实现类似新浪微博长URL转短地址的方法

    2023-06-02 12:59:28
  • java根据List内对象的属性排序方法

    2022-10-25 10:05:44
  • kotlin之协程的理解与使用详解

    2023-10-21 15:55:57
  • java多次嵌套循环查询数据库导致代码中数据处理慢的解决

    2023-10-28 22:17:50
  • 探讨Java验证码制作(下篇)

    2023-04-04 11:21:42
  • JWT在OpenFeign调用中进行令牌中继详解

    2023-02-07 04:19:15
  • Java实现人机猜拳小游戏

    2023-10-07 16:11:37
  • 详解Java中的ReentrantLock锁

    2023-07-18 10:00:45
  • springmvc分层领域模型概念详解

    2021-09-07 01:21:51
  • Java服务限流算法的6种实现

    2022-04-03 04:52:51
  • 教你如何使用Java8实现菜单树形数据

    2022-09-11 12:29:22
  • Java 十大排序算法之归并排序刨析

    2022-03-15 17:29:20
  • 解析android中的dip,dp,px,sp和屏幕密度

    2023-09-26 20:44:38
  • asp之家 软件编程 m.aspxhome.com