Spring Boot AOP处理请求 Spring Boot学习入门之AOP处理请求详解
a60782885 人气:0想了解Spring Boot学习入门之AOP处理请求详解的相关内容吗,a60782885在本文为您仔细讲解Spring Boot AOP处理请求的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:spring,boot,aop,spring,boot,aop,例子,spring,boot,aop,注解,下面大家一起来学习吧。
前言
面向切面(AOP)Aspect Oriented Programming是一种编程范式,与语言无关,是一种程序设计思想,它也是spring的两大核心之一。
在spring Boot中,如何用AOP实现拦截器呢?
首先加入依赖关系:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
希望截拦如下Controller:
@RestController public class MyController { @RequestMapping(value="/hello", method=RequestMethod.GET) public String hello() { return ""; } }
首先要创建一个拦截类:RequestInterceptor
并且使用@Aspect和@Component标注这个类:
@Component @Aspect public class RequestInterceptor { @Pointcut("execution(* com.example.controller.*.*(..))") public void pointcut1() {} @Before("pointcut1()") public void doBefore() { System.out.println("before"); } @Around("pointcut1()") public void around(ProceedingJoinPoint thisJoinPoint) throws Throwable { System.out.println("around1"); thisJoinPoint.proceed(); System.out.println("around2"); } @After("pointcut1()") public void after(JoinPoint joinPoint) { System.out.println("after"); } @AfterReturning("pointcut1()") public void afterReturning(JoinPoint joinPoint) { System.out.println("afterReturning"); } @AfterThrowing("pointcut1()") public void afterThrowing(JoinPoint joinPoint) { System.out.println("afterThrowing"); } }
只需要使用@Before,@After等注解就非常轻松的实现截拦功能。
这里需要处理请求,所以我们需要在拦截器中获取请求。
只需要在方法体中使用:
ServletRequestAttributes attributes =(ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest();
就可以获取到request。
同理也可以在After等方法中获取response。
获取request之后,就可以通过request获取url,ip等信息。
如果我们想要获取当前正在拦截的方法的信息。可以使用JoinPoint。
例如:
@After("pointcut1()") public void after(JoinPoint joinPoint) { logger.info("CLASS_METHOD : " + joinPoint.getSignature().getDeclaringTypeName()+ "." + joinPoint.getSignature().getName()); System.out.println("after"); }
就可以获取包名,类名,方法名。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
加载全部内容