SPRINGBOOT9--AOP的使用(本例展示统一处理Web请求日志)

AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。

AOP是Spring框架中的一个重要内容,它通过对既有程序定义一个切入点,然后在其前后切入不同的执行内容,比如常见的有:

打开数据库连接/关闭数据库连接、打开事务/关闭事务、记录日志等。基于AOP不会破坏原来程序逻辑,因此它可以很好的对业务逻辑的各个部分进行隔离,

从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

准备工作:

pom中引入:

<dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-web</artifactId></dependency>

* Spring Boot中使用AOP统一处理Web请求日志
* 使用@Aspect注解将一个java类定义为切面类
* 使用@Pointcut定义一个切入点,可以是一个规则表达式,比如下例中某个package下的所有函数,也可以是一个注解等。
* 根据需要在切入点不同位置的切入内容
* 使用@Before在切入点开始处切入内容
* 使用@After在切入点结尾处切入内容
* 使用@AfterReturning在切入点return内容之后切入内容(可以用来对处理返回值做一些加工处理)
* 使用@Around在切入点前后切入内容,并自己控制何时执行切入点自身的内容
* 使用@AfterThrowing用来处理当切入内容部分抛出异常之后的处理逻辑

/***
* 在WebLogAspect切面中,分别通过doBefore和doAfterReturning两个独立函数实现了切点头部和
* 切点返回后执行的内容,若我们想统计请求的处理时间,就需要在doBefore处记录时间,并在doAfterReturning
* 处通过当前时间与开始处记录的时间计算得到请求处理的消耗时间。
* 那么我们是否可以在WebLogAspect切面中定义一个成员变量来给doBefore和doAfterReturning一起访问呢?
* 是否会有同步问题呢?
* 的确,直接在这里定义基本类型会有同步问题,所以我们可以引入ThreadLocal对象
*/

/***
* 优化:AOP切面的优先级
* 由于通过AOP实现,程序得到了很好的解耦,但是也会带来一些问题,比如:我们可能会对Web层做多个切面,校验用户,校验头信息等等,这个时候经常会碰到切面的处理顺序问题。
* 所以,我们需要定义每个切面的优先级,我们需要@Order(i)注解来标识切面的优先级。i的值越小,优先级越高。假设我们还有一个切面是CheckNameAspect用来校验name必须为didi,
* 我们为其设置@Order(10),而上文中WebLogAspect设置为@Order(5),所以WebLogAspect有更高的优先级,这个时候执行顺序是这样的:
* 在@Before中优先执行@Order(5)的内容,再执行@Order(10)的内容
* 在@After和@AfterReturning中优先执行@Order(10)的内容,再执行@Order(5)的内容
* 所以我们可以这样子总结:
* 在切入点前的操作,按order的值由小到大执行
* 在切入点后的操作,按order的值由大到小执行
*/

原文地址:https://www.cnblogs.com/ajax-li/p/9233280.html

时间: 2024-12-31 03:23:15

SPRINGBOOT9--AOP的使用(本例展示统一处理Web请求日志)的相关文章

SpringBoot2.0 使用AOP统一处理Web请求日志(完整版)

一,加入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> 二,在src/main/java下的某个包中新建类 : import org.aspectj.lang.JoinPoint; import org.aspectj.lang.Proce

使用AOP统一处理Web请求日志

pom文件添加依赖 <!--AOP统一处理Web请求日志--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> 使用示例: package vxsoft.cn.tts.config; import java.util.Enumerat

Spring Boot中使用AOP统一处理Web请求日志

AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.AOP是Spring框架中的一个重要内容,它通过对既有程序定义一个切入点,然后在其前后切入不同的执行内容,比如常见的有:打开数据库连接/关闭数据库连接.打开事务/关闭事务.记录日志等.基于AOP不会破坏原来程序逻辑,因此它可以很好的对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率.

SpringBoot使用AOP统一处理Web请求日志

<!--aop依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> @Aspect @Component public class WebLogAspect { private static final Logger logge

springboot Aop 统一处理Web请求日志

1.增加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> 2.编写切面类 @Aspect @Component public class WebLogAspect {} 注解 @Aspect 表明这是个切面类 3.定义切点 @Pointcut

Topshelf 和 Katana:统一的 Web 和服务体系结构

转自:https://msdn.microsoft.com/zh-cn/magazine/dn745865.aspx ASP.NET Topshelf 和 Katana:统一的 Web 和服务体系结构 Wes McClure 下载代码示例 使用 IIS 托管 ASP.NET Web 应用程序已成为业界标准十年有余.构建此类应用程序的过程相对简单,但部署它们则并不容易.部署此类应用程序需要掌握应用程序配置层次结构的精妙知识.IIS 历史版本的细微差别,以及对网站.应用程序和虚拟目录的繁琐设置.许多

jfinal统一的异常及日志处理的拦截器

最近在用轻量级Java web开发框架jfinal开发一个网站,由于网站是sns类型很多ajax交互请求. 考虑简化冗余代码,写了一个统一的异常及日志处理的拦截器. 自适配ajax请求和普通定向请求,输出错误信息. 直接上代码吧 package com.smhaochi.web.interceptor; import java.util.Date; import java.util.Map; import java.util.Set; import javax.servlet.http.Http

一般处理程序结合反射技术统一执行客户端请求

思考: 在开发中,如果使用了模板技术+一般处理程序开发,应用中用户的请求可能在程序中都存在一个共性的操作. 例如,每当执行请求时要检查用户是否是登陆,请求时检查用户是否具有相应权限等等的共性的操作,我们不可能每个页面都写上对于操作,那样显然不符合面向对象的思想,存在大量冗余. 如何去解决呢? 解决思路: 创建一个父类实现IHttpHandler接口,让处理请求的一般处理程序实现这个接口,当一般处理程序接收到请求时,去统一执行父类里的ProcessRequest()方法. 客户端发出的请求,要约定

Cocos2d-x 3.2 Lua演示样例 XMLHttpRequestTest(Http网络请求)

Cocos2d-x 3.2 Lua演示样例 XMLHttpRequestTest(Http网络请求) 本篇博客介绍Cocos2d-x 3.2Lua演示样例中的XMLHttpRequestTest,这里提供GET和POST两种http请求方式,返回数据类型有下面几种: cc.XMLHTTPREQUEST_RESPONSE_STRING = 0  -- 返回字符串类型cc.XMLHTTPREQUEST_RESPONSE_ARRAY_BUFFER = 1 -- 返回字节数组类型cc.XMLHTTPRE