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,aroundPointcut
(切入点):就是带有通知的连接点,在程序中主要体现为书写切入点表达式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的管理日志,蛋疼的很....
老规矩贴代码吧
首先除了aop的包以外需要这三个包。
自行度娘。
如果想切入controllers,请将这个代码写入你的mvc配置中,纠结了一上午切不进去就是这个原因.
method为你切入类的方法名
可以照这个打个模版出来,PS:无视注释哈,逼死强迫症
因为我的控制类里面只会有两个参数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 中, IOC 是很重要的概念,其本质就是 map 结构,存储容器和业务 Be
- 部署在tomcat容器中首先需要添加一些新的包和启动程序1.在pom.xml文件中packaging便签下 jar 改为 war<pa
- 缘起工作时使用java开发服务器后台,用Jersey写Restful接口,发现有一个Post方法始终获取不到参数,查了半天,发现时获取参数的
- import java.text.ParseException;import java.text.SimpleDateFormat;impo
- 前言最近发现公司的微服务项目中没有统一的批量新增方法,公司用的是MP插件,遇到批量新增都是单独去去编写xml实现,费时费力,而MP自带的批插
- 一、findById(ID id)通过id进行单条查询,先看看 findById(ID id) 的源码@Overridepublic Opt
- UI 妹纸又给了个图叫我做,我一看是这样的:我们首先把这个控件划分成 几个部分:1.底下部分的直线 :2.左右两边的半圆
- 记录一下工作流的在Springboot中的使用,,顺便写个demo,概念,什么东西的我就不解释了,如有问题欢迎各位大佬指导一下。1.创建sp
- 什么是JavaMemoryModel(JMM)?JMM通过构建一个统一的内存模型来屏蔽掉不同硬件平台和不同操作系统之间的差异,让Java开发
- 本文研究的主要是Java中后台线程的相关问题,具体介绍如下。以前从来没有听说过,java中有后台线程这种东西。一般来说,JVM(JAVA虚拟
- 前言最近在刷java面试题偶然看到这类问题(try/finally中含有return时的执行顺序),觉得挺有意思于是小小的研究了一下,希望经
- 概述在移动应用开发中,消息推送可以说是一项非常重要的功能,它能够起到提醒或者唤醒用户的作用,同时也是产品运营人员更高效地实现运营目标的重要手
- 项目中要使用到在线支付功能 目前常用的在线支付手段主要是 支付宝 和微信。 这里我使用的是支付宝支付,支付宝有个好处就是他有一个沙箱模式 即
- 显示当前运行java代码的运行时的各种参数。不带显String操作。package systeminfo;import java.util.
- 开篇本文主要来探讨一下 redis 的单线程模型,文章前半部分会先引用某网络课程讲解的内容(图片+语言描述),后半部分是本人粗略阅读 red
- Allatori混淆技术介绍Allatori是一个Java 混淆器,它属于第二代混淆器,因此它能够全方位地保护你的知识产权。 Allator
- 五子棋AI算法也算是一个典型的游戏AI算法,一些棋类的AI算法都可以参考实现,下面是Java实现代码棋盘抽象接口import java.ut
- 概述对List进行分组是日常开发中,经常遇到的,在JDK 8中对List按照某个属性分组的代码,超级简单。package test;impo
- 前言在RocketMQ中为,我们创建消息生产者时,只需要设置NameServer地址,消息就能正确地发送到对应的Broker中,那么Rock
- startActivityForResult与startActivity的不同之处在于:1、startActivity( )仅仅是跳转到目标