【JavaEE】Spring全家桶实现AOP-统一处理

这篇具有很好参考价值的文章主要介绍了【JavaEE】Spring全家桶实现AOP-统一处理。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【JavaEE】AOP(2)

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】AOP(2)

在前面的Spring AOP的学习之中,Spring AOP去实现AOP,虽然比较灵活,可以实现很多想法,但是也有一些现实的问题:

  1. 没办法获取到HttpRequest,一些功能难以实现
    • 进而无法获取HttpSession对象,这样登录校验功能就无法实现
  2. 我们要对⼀部分方法进行拦截,而另⼀部分方法不拦截,如注册方法和登录方法是不拦截的,这样的话排除方法的规则很难定义,甚至没办法定义

我们手动去实现,太难了!

所以本文讲解的重点就是,Spring全家桶实现AOP的几种固定的机制,虽然较不灵活,但是实现的功能有针对性,且代码简单!

  • 只要我们按照框架的要求去写,就可以实现对应的功能
  • 这些功能都是很常见、很必要的功能!
    • 所以不要纠结于这个框架不够全面,不能实现一些极端特殊的要求,因为它只是 把一切常见的功能,打包成现成的模块 ,方便开发;如果有其他特殊要求,用Spring AOP等等偏底层地去实现就好了!
    • 框架就是这样的,方便一些常见开发的操作,我们不需要过多了解底层实现,“坐享其成”即可😀
    • Spring全家桶实现AOP更偏向于具体的统一处理功能,而Spring AOP实现AOP更偏底层

网路资料:

Spring AOP是Spring框架中的一个模块,用于实现面向切面编程。它通过动态代理或者字节码生成的方式,在运行时将横切逻辑织入到目标对象的方法中,从而在目标对象执行前、执行后或者执行异常时执行额外的操作。Spring AOP主要基于代理模式来实现。


Spring Boot框架是基于Spring框架的扩展,用于简化和加速Spring应用程序的开发。


Spring Boot并没有重新实现AOP概念,而是直接继承了Spring框架中的AOP模块,因此在Spring Boot中,使用AOP的方式和Spring框架中的方式是一样的。Spring Boot提供了更方便的自动配置和默认约定,使得使用AOP更加简单。


因此,Spring AOP和Spring Boot框架实现的AOP的本质是相同的,都是通过代理方式实现的面向切面编程。区别主要在于Spring全家桶提供了[更简化的配置]和[默认约定],使得使用AOP更加方便。

  • 因为代码的运行就是通过 Spring Boot框架来运行的,以此来控制一些逻辑也很合理!

本文讲解的几个统一处理:

  1. 统一登录校验处理
    • Spring 拦截器
  2. 统一异常处理
  3. 统一数据格式返回处理

没学到不代表不重要,需要用到什么统一处理的功能,再专门去学!

1. 统一登录校验处理

框架的学习说到底就是学习一个约定,按照约定才能实现方便功能~

Spring全家桶提供了具体的现成拦截器:HandlerInterceptor ,应用拦截器分为两步:

  1. 创建自定义拦截器,实现 HandlerInterceptor接口,重写 preHandle方法

    • preHandle() => 目标方法执行之前要执行的预处理方法

    • 其返回值为true/false

      1. true=>目标方法可执行,放行

      2. false=>目标方法不可执行,拦截

        //伪代码
        HandlerInterceptor o = new LoginInterceptor(); 
        if(!o.preHandle(...)) {
            return;
        }
        targetMethod();
        
  2. 重写 WebMvcConfigureraddInterceptors(InterceptorRegistry registry)方法

    • 添加拦截器到registry中(登记)
      • 可以添加多个拦截器,按顺序进行拦截(如果逻辑冲突,按照顺序,以第一个结果为准)
    • 添加拦截的路由/排除拦截的路由

1.1 自定义拦截器

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

Ctrl O重写方法:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

默认返回true,放行

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

Java对于一些常量通常会放在一个类里面,以访问的形式去获取常量,而不是每次都手敲:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

1.2 将自定义拦截器加入到系统配置

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

Ctrl O重写方法:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 加Configuration!否则项目启动不会加载这个类,自然不会进行系统配置
  • 实现MebMvcConfigurer,自然就是跟Spring Mvc(网络相关)有关的配置
  • 不仅仅只有配置文件才能配置,配置类也可以哦!

拦截器对象加入到Spring容器里

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

一般写成这样:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • PathPatterns,路径的样式

  • 其实直接new一个咱们的拦截器对象甚至匿名内部类重写那个方法也行,因为这个参数只是定义预处理方法

  • 这个类只是游离在外的普通类,一个拦截器的定义罢了~

为什么可以怎么写:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 其实就是因为每个加或者减后返回的都是同一个对象~

1.3 测试

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

为了突出结果,做出以下改动:

  1. 拦截成功跳转百度:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  1. 提示执行了拦截器

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  1. 排除路由/test/say_hello

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端


【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

1.4 对于静态资源的处理

比如图片/html/js/css等资源,如果是服务器的,都是向服务器请求来的

  • html等等很常规无非就是:.excludePathPatterns("/**/*.html")

  • 但是图片不一样,图片的格式很多很多,我们没办法一一列举,而我们可以这么做:

    • 将图片保存到一个目录image里,然后排除整个image目录
    • .excludePathPatterns("/image/**")

1.5 小练习:统一登录拦截处理

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

将我们之前做的博客前端资源拷贝到static里:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

后端基本上代码不变,主要是对静态资源和一些路由的拦截排除:

有可能有缓存的问题,刚才的资源没有出现在target中,所以要删掉重新启动

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

重定向只是 对应的路径 相当于重定向后的路径,所以如果只是请求资源或者请求响应数据,不是访问 对应的路径 的网页,是不会触发跳转的~

  • 只会表现为访问不到资源/响应状态码为302

例如:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 背景消失~

补充,静态资源以static为起始,接受多级目录访问:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

注意删除target重新启动!

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

1.6 拦截器原理

1.6.1 执行流程

之前:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

现在:

  • 就在请求的传递路上"截胡"

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

1.6.2 源码分析

所有的Controller执行都会通过一个调度器DispatcherServlet来实现,可以通过控制台的日志观察到:(前提是拦截器工作了!)

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

双击shift查找DispatcherServlet:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 这个就是我们重写的方法!
  • 循环拦截器集合(多个拦截器的情况)

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

true就可以继续进行后面的程序(我们的目标方法就在后面)

false就直接return(响应通过输出型参数response返回)

  • 客户端发送请求后,在Spring MVC框架中会经过一系列的组件处理,其中就有可能被拦截器 “截胡”

1.7 扩展:统一访问前缀添加

所有请求地址添加api前缀:

@Configuration//不是Configurable!
public class AppConfig implements WebMvcConfigurer {
    @Override
    public void configurePathMatch(PathMatchConfigurer configurer) {
        configurer.addPathPrefix("api", c -> true);
    }
}
  1. api,原有路由多一级
    • 但是不代表默认不被拦截!
    • 还是要去排除/api/…
    • 还会导致原有路由不能用
  2. c -> true,是一个表达式(不需要了解,感兴趣可以了解),表示启动前缀,false则无效果

2. 统一异常处理

2.1 为什么需要异常处理

如果后端报异常:

(监视器已关掉,此处重点观察异常)

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

信息太过杂,我们需要总结要点,但是不能边开发边写这些异常处理操作,而且几个开发者写的可能都不一样,后期也不方便维护,所以要统一处理~

所以我们希望异常返回的时候应该有明确统一的信息!

网路资料(了解):

  1. 错误处理的一致性:通过统一处理异常,可以确保应用程序在遇到异常时采取一致的处理方式。这样可以提供更好的用户体验,避免不一致的错误展示或处理方式。

  2. 代码的可维护性:通过将异常处理逻辑集中到一个地方,可以提高代码的可维护性。如果每个控制器方法都有自己的异常处理逻辑,会导致代码重复和冗余,难以维护和更新。

  3. 封装敏感信息:统一处理异常可以帮助我们封装敏感信息,防止泄露给客户端。在异常处理过程中,我们可以选择性地披露或隐藏敏感信息,并返回友好的错误消息给客户端。

  4. 日志记录和监控:通过统一处理异常,我们可以方便地进行日志记录和监控。在异常处理过程中,我们可以记录异常的详细信息,包括异常类型、堆栈跟踪等,以便后续的故障排查和系统监控。

  5. 异常转换和包装:有时候,我们可能需要将底层的异常转换为更高级别的异常,或者将多个异常包装为一个更通用的异常。通过统一处理异常,可以方便地进行这些异常转换和包装操作,以便更好地传递和处理异常。

  6. 错误页面的统一管理:通过统一处理异常,可以将错误页面的管理集中到一个地方。这样可以更方便地自定义错误页面,并确保所有的异常都有对应的错误展示界面。

总之,通过统一处理异常,我们可以提高代码的可维护性和可读性,封装敏感信息,方便日志记录和监控,进行异常转换和包装,以及统一管理错误页面。这些都有助于提升应用程序的质量和用户体验。

大概了解一下就行了,实际项目遇到去使用体验会更好!

2.2 应用异常处理器

我们仍然有现成的异常处理器可以用,如何应用:

  1. @ControllerAdvice
    • 加在类上,代表其为控制器通知类此类会“监听”后端环境,随着项目启动的加载,如果抛出异常会被此类感知到
  2. @ExceptionHandler(Exception.class)
    • 顾名思义,这就是异常处理器,加在方法上,其返回值就是格式化后的数据,注解的括号内应该为对应异常的类对象,并且这个方法可以有一个参数e(名字自取),e会被注入刚才的异常对象
    • 会在获取到异常后调用这个方法,(AOP advice的位置)

补充:

返回的格式以json为最佳,所以返回的方式有两种:

  1. 自定义对象/自定义对象集合
  2. Map对象,自定义映射关系
    • 方便,以这个为例

返回值的类型可以是Object,包括其泛型或者其属性,系统会自动去获取每一个都是谁向上转型而来的

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 无论什么异常都会被这个异常处理器捕捉到,因为Exception是所有异常的父类,而参数e则是被向上转型来的,所以其getMessage方法被重写了,仍然可以正常使用
  • 随便写的,只是示例!

但是对于潜在的个别异常,如NullPointerException,应该单独处理,并且被子类捕获就不会被父类捕获了~

  • 因为异常太多了,所以还是需要Exception这个"老父亲"来兜底

效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

其他异常效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

3. 统一数据格式返回处理

3.1 为什么要统一数据格式

其实每个公司都会对字段名严格必须符合规范,但是返回的格式则千奇百怪

统一数据格式的优点很多,比如以下几个:

  1. 方便前后端程序员对接数据
  2. 降低前后端沟通成本,所有接口都按一个格式返回
  3. 有利于项目统一数据的维护和修改
  4. 有利于后端技术部门的统一规范,不会出现稀奇古怪的返回内容

3.2 数据格式统一方法

一样可以按照刚才的两种方式:

  1. 自定义对象
    • 本次演示这种,因为有个小坑
  2. Map

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

现在我们分为两种情况:

  1. 成功是一个方法

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  1. 失败是一个方法

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

3.3 应用数据格式返回统一处理器

我们仍然有现成的数据格式返回统一处理器可以用,如何应用:

  1. @ControllerAdvice
    • 加在类上,代表其为控制器通知类此类会“监听”后端环境,随着项目启动的加载,如果有返回值就会被捕获到!
  2. 实现接口ResponseBodyAdvice
    1. 重写supports方法,表示我们是否要重写beforeBodyWrite方法
      • 通过这个方法以及参数我们可以动态的选择性的对一些控制器和方法不重写/重写
      • return true代表可以重写,反之不能重写
    2. 重写beforeBodyWrite方法
      • 顾名思义就是“篡改”返回值,这个方法会在方法返回之前调用,替原方法返回值,(AOP advice的位置)
      • 默认返回像加了@ResponseBody

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

测试:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 返回值类型已经不重要了,因为都会被返回值统一处理掉
  • 当然写原来的类型会更好,因为这样有利于代码的正确性,并且此接口可能被处理器排除了~

效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

3.4 String类型无法处理的问题

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

  • 因为异常处理,把异常处理的信息再次看成返回值了,实际上返回值处理器运行了两次🤣

因为框架在对返回数据格式处理的时候分为两类:

  1. body是非String类型向上转型而来
    • 跟原来一样,返回值Result类型可以直接返回,框架自动转换为json字符串
  2. body是String类型向上转型而来
    • 也跟原来一样,应该返回String类型并且视作html代码,Result类型的返回值尝试转换为String类型,但是Result类型无法直接转换为String类型!
    • 因为框架【并没有】将它看成非String对象返回,然后按非String对象的方式转换为json字符串!
    • 然后把Result对象看成String对象返回,显然直接报异常!
      • 证据就是,Result对象是完好的,只要调用toString方法返回,不会报异常,但是直接返回Result会报异常。说明返回值必须是字符串,并且最终会被渲染

所以我们应该对String类型单独处理:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

效果:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

在浏览器中,这段字符串被认为是html:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端
【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端
可见刚才的结论~

因为响应中Content-Type并非application/json

  • 因此前端收到这个响应,并不会直接将body视作json对象,而是字符串(html代码),所以我们要用jquery的现成方法转化为json对象才行

3.5 @ControllerAdvice 源码分析

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

跟其他类注解一样派生于@Component,而所有的组件都会调用InitializingBean接口:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

Spring MVC中的RequestMappingHandlerAdapter,实现了它:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

实现了afterPropertiesSet方法:

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

异常处理器和返回值处理器的核心前提就是有这个注解,原因归功于它的监听机制

  • 我们发现,这些ControllerAdvice注解类Bean对象特殊地被查找和存储在容器之中它们比较“忙”当发生某个事件的时候,调用对应的Advice方法,比如统一异常处理,统一返回值格式处理…
    【JavaEE】Spring全家桶实现AOP-统一处理,JavaEE,java-ee,spring,java,统一处理,后端

文章到此结束!谢谢观看
可以叫我 小马,我可能写的不好或者有错误,但是一起加油鸭🦆

本文重点讲基本使用方法,具体功能实现要结合实际应变!

  • 例如拦截后咋样,异常处理格式咋样,统一数据格式返回咋样…都不是固定的,是根据实际情况的!

代码:spring_boot_aop_demo/src/main/java/com/example/demo · 游离态/马拉圈2023年8月 - 码云 - 开源中国 (gitee.com)文章来源地址https://www.toymoban.com/news/detail-678614.html


到了这里,关于【JavaEE】Spring全家桶实现AOP-统一处理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaEE进阶 Spring AOP(6/1)

    目录 1.什么是AOP 2.Spring AOP可以干什么 3.AOP的组成成分 4.SpringAOP实现步骤 5.SpringAOP的原理 1.什么是AOP AOP是面向切面编程,是一种思想 Spring AOP是一种具体的技术 2.Spring AOP可以干什么 1.用户登录状态的判断 2.统一的日志记录(比如记录访问次数) 3.统一方法执行实践 3.AOP的组成

    2024年02月07日
    浏览(26)
  • Spring Boot 优雅实现统一数据返回格式+统一异常处理+统一日志处理

            在我们的项目开发中,我们都会对数据返回格式进行统一的处理,这样可以方便前端人员取数据,当然除了正常流程的数据返回格式需要统一以外,我们也需要对异常的情况进行统一的处理,以及项目必备的日志。         在项目开发中返回的是json格式的数据

    2024年01月19日
    浏览(32)
  • 【JavaEE】面向切面编程AOP是什么-Spring AOP框架的基本使用

    【JavaEE】 AOP(1) 1.1 AOP 与 Spring AOP AOP ( A spect O riented P rogramming),是一种思想,即 面向切面编程 Spring AOP 则是一个框架,Spring项目中需要引入依赖而使用 AOP和Spring AOP的关系就相当于IoC和DI Spring AOP让开发者能够半自动的开发AOP思想下实现的功能 1.2 没有AOP的世界是怎样的

    2024年02月11日
    浏览(30)
  • javaee spring aop 的五种通知方式

    2024年02月10日
    浏览(29)
  • javaee spring aop 切入点表达式

    1、切入点表达式:对指定的方法进行拦截,并且生成代理表达式。 2、表达式不同写法 1.匹配指定方法 1 aop:pointcut expression=\\\"execution( public void com.test.service.impl.UsersService.add())\\\" id=\\\"pt\\\"/ 2.默认 public 可以省略 2 aop:pointcut expression=\\\"execution( void com.test.service.impl.UsersService.add())\\\" id=“p

    2024年02月10日
    浏览(34)
  • 【JavaEE进阶】——第八节.SpringBoot统一功能处理

    作者简介:大家好,我是未央; 博客首页: 未央.303 系列专栏:JavaEE进阶 每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!! 文章目录 前言 一、统一用户的登录 1.1 Spring AOP 实现用户统一登录验证 1.2Spring拦截器实现统一用户的登录验证 1.3 实例演示(通

    2024年02月07日
    浏览(35)
  • Spring Boot实现统一异常处理的技术解析

    引言 在软件开发过程中,异常处理是非常重要的一环。一个好的异常处理机制可以帮助我们更好地定位问题,提高代码的可维护性和稳定性。Spring Boot作为一款轻量级的Java开发框架,提供了一种简单而高效的方式来实现统一异常处理。本文将详细介绍如何使用Spring Boot实现统

    2024年01月21日
    浏览(29)
  • Spring Boot 统一功能处理(拦截器实现用户登录权限的统一校验、统一异常返回、统一数据格式返回)

    目录 1. 用户登录权限校验 1.1 最初用户登录权限效验 1.2 Spring AOP 用户统⼀登录验证 1.3 Spring 拦截器 (1)创建自定义拦截器 (2)将自定义拦截器添加到系统配置中,并设置拦截的规则 1.4 练习:登录拦截器 (1)实现 UserController 实体类 (2)返回的登录页面:login.html (3)实

    2024年02月12日
    浏览(34)
  • Spring Boot 自定义注解,AOP 切面统一打印出入参请求日志

    今天主要说说如何通过自定义注解的方式,在 Spring Boot 中来实现 AOP 切面统一打印出入参日志。小伙伴们可以收藏一波。 废话不多说,进入正题! 在看看实现方法之前,我们先看下切面日志输出效果咋样: 从上图中可以看到,每个对于每个请求,开始与结束一目了然,并且

    2024年02月08日
    浏览(37)
  • JAVA:使用 Spring AOP 实现面向切面编程

    1、简述 在现代的软件开发中,面向切面编程(AOP)是一种重要的编程范式,它允许我们将横切关注点(如日志记录、性能监控、事务管理等)从应用程序的核心业务逻辑中分离出来,以提高代码的模块化和可维护性。Spring 框架提供了强大的 AOP 支持,使得我们可以轻松地实

    2024年04月13日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包