SpringBoot集成AOP过程?

AOP简介

面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术,AOP是OOP的延续。简单的说它就是把我们程序重复的代码抽取出来,在需要执行的时候,使用动态代理技术,在不修改源码的基础上,对我们已有的方法进行增强。

相关概念

Joinpoint(连接点)

所谓连接点是指那些被拦截到的点。在 spring 中,这些点指的是方法,因为 spring 只支持方法类型的连接点。

Pointcut(切入点)

所谓切入点是指我们要对哪些 Joinpoint 进行拦截的定义。

Advice(通知/增强)

所谓通知是指拦截到 Joinpoint 之后所要做的事情就是通知。
通知的类型:前置通知,后置通知,异常通知,最终通知,环绕通知。

Introduction(引介)

引介是一种特殊的通知在不修改类代码的前提下, Introduction 可以在运行期为类动态地添加一些方法或 Field。

Target(目标对象)

代理的目标对象。

Weaving(织入)

是指把增强应用到目标对象来创建新的代理对象的过程。

Proxy(代理)

一个类被 AOP 织入增强后,就产生一个结果代理类。

Aspect(切面)

是切入点和通知(引介)的结合。

在spring 中,框架会根据目标类是否实现了接口来决定采用哪种动态代理的方式。
在spring 中,2.0默认采用CGLIB代理,如果需要基于接口的动态代理(JDK基于接口的动态代理) ,需要设置spring.aop.proxy-target-class属性为false。
spring的动态代理,借用了AspectJ的注解。

引入依赖

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-aop</artifactId>

        </dependency>

Controller层编写

@Controller

@RequestMapping("aspect")

@Api(tags = "切面")

public class AspectController {

    @ApiOperation("切面通知")

    @RequestMapping(value = "/sayHello",method = RequestMethod.GET)

    @ResponseBody

    public Object sayHello(String name){

        System.out.println("---------------------方法执行----------------");

        return "hello " + name;

    }

}

切面类编写

@Aspect //表示当前类是一个切面类

@Component

@Slf4j

public class AspectConfig {

    /**

     *   定义切入点,切入点为com.yxkj.springbootdemo.controller下的所有函数

     *

     **/

    @Pointcut("execution(public * com.yxkj.springbootdemo.controller..*.*(..))")

    public void root(){}

    //当前方法是异常通知

    @AfterThrowing("root()")

    public void rollback() {

        log.info("当前方法是一个异常通知");

    }

    //当前方法是最终通知

    @After("root()")

    public void release() {

        log.info("当前方法是一个最终通知");

    }

    //环绕通知

    @Around("root()")

    public Object transactionAround(ProceedingJoinPoint pjp) throws Throwable {

            //定义返回值

            Object rtValue = null;

           //获取方法执行所需的参数

            Object[] args = pjp.getArgs();

            log.info("环绕通知执行方法前,传入参数"+args[0]);

            //执行方法

            rtValue = pjp.proceed(args);

            log.info("环绕通知执行方法后,传出参数"+rtValue);

            return rtValue;

    }

    @Before("root()")

    public void doBefore(JoinPoint joinPoint) throws Throwable {

        // 接收到请求,记录请求内容

        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

        HttpServletRequest request = attributes.getRequest();

        // 记录下请求内容

        log.info("前置通知:URL : " + request.getRequestURL().toString());

        log.info("前置通知:HTTP_METHOD : " + request.getMethod());

        log.info("前置通知:IP : " + request.getRemoteAddr());

        log.info("前置通知:CLASS_METHOD : " + joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName());

        log.info("前置通知:传入参数 : " + Arrays.toString(joinPoint.getArgs()));

    }

    @AfterReturning(returning = "ret", pointcut = "root()")

    public void doAfterReturning(Object ret) throws Throwable {

        // 处理完请求,返回内容

        log.info("后置通知:返回参数 : " + ret);

    }

}

访问方法结果

13 08:50:25.453 INFO ||:环绕通知执行方法前,传入参数123213

13 08:50:25.454 INFO ||:前置通知:URL : http://127.0.0.1:8088/springbootdemo/aspect/sayHello

13 08:50:25.454 INFO ||:前置通知:HTTP_METHOD : GET

13 08:50:25.454 INFO ||:前置通知:IP : 127.0.0.1

13 08:50:25.455 INFO ||:前置通知:CLASS_METHOD : com.yxkj.springbootdemo.controller.AspectController.sayHello

13 08:50:25.455 INFO ||:前置通知:传入参数 : [123213]

---------------------方法执行----------------

13 08:50:25.457 INFO ||:后置通知:返回参数 : hello 123213

13 08:50:25.457 INFO ||:当前方法是一个最终通知

13 08:50:25.457 INFO ||:环绕通知执行方法后,传出参数hello 123213

Gitee地址

SpringBootDemo/src/main/java/com/yxkj/springbootdemo/config/AspectConfig.java · 晨度/FoundationStudy - Gitee.com

XFS

分类: spring、springMVC、springboot、springcloud、Dubbox

FFmpeg是一款功能强大的开源多媒体处理工具,广泛应用于视频和音频的编码、解码、转换以及流媒体处理。然而,由于历史原因和标准限制,原生的FFmpeg并不支持将H.265(高效视频编码)格式的视频流封装到FLV(Flash Video)容器中。FLV是一种常见的网络流媒体传输格式,但其最初设计时并未考虑现代高效的H.265编码标准。因此,当尝试将H.265编码的视频与FLV容器结合时,会出现“Video codec hevc not compatible with flv”的错误提示,表明FFmpeg无法识别这种组合。 为了解决这一问题,开发者通常需要对FFmpeg的源代码进行修改和扩展。一个名为“用于解决ffmpeg不支持flv+h265需要修改的文件.zip”的压缩包中包含了一些源代码文件,这些文件旨在扩展FFmpeg的功能,使其能够处理FLV容器中的H.265编码内容。压缩包中的三个关键文件分别是“flvdec.c”“flvenc.c”和“flv.h”,它们分别对应FLV的解码器、编码器和头文件。 flvdec.c:这是FFmpeg的FLV解码器源代码,经过修改后可能支持读取和解析包含H.265数据的FLV流。解码器的作用是从FLV容器中提取视频数据,并将其转换为可处理的原始像素格式。 flvenc.c:这个文件包含FLV编码器的源代码,经过调整后可能允许将H.265编码的视频流封装到FLV容器中。编码器负责将原始视频数据编码为H.265格式,并将其打包到FLV文件中。 flv.h:这是一个头文件,定义了FLV格式相关的常量、结构体和函数原型。修改该文件可能涉及添加或更新与H.265支持相关的定义和接口。 要应用这些修改,开发者需要重新编译FFmpeg源代码,并将修改后的版本替换原有的FFmpeg安装。这样,用户就可以使用定制版的FFmpeg来处理FLV+H.265的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值