-
autoLog-02-java 注解结合 spring aop 实现日志traceId唯一标识
MDC 的必要性
日志框架
日志框架成熟的也比较多:
slf4j
log4j
logback
log4j2
我们没有必要重复造轮子,一般是建议和 slf4j 进行整合,便于后期替换为其他框架。
日志的使用
基本上所有的应用都需要打印日志,但并不是每一个开发都会输出日志。
主要有下面的问题:
(1)日志太少,出问题时无法定位问题
(2)日志太多,查找问题很麻烦,对服务器...
2023-08-06 00:00:00 |
Trace
-
autoLog-01-java 注解结合 spring aop 实现自动输出日志
java 注解结合 spring aop 实现自动输出日志
auto-log
auto-log 是一款为 java 设计的自动日志监控框架。
创作目的
经常会写一些工具,有时候手动加一些日志很麻烦,引入 spring 又过于大材小用。
所以希望从从简到繁实现一个工具,便于平时使用。
特性
基于注解+字节码,配置灵活
自动适配常见的日志框架
...
2023-08-06 00:00:00 |
Trace
-
spring @Scope 注解与 ScopedProxyMode 入门介绍
背景
今天看到了 @Scope 用来可以指定 spring 的代码模式,比如指定基于动态代理,这个挺不错的。
记录一下,以前学习过,但是没有注意过。
源码
@Scope 注解
@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @...
2023-08-02 00:00:00 |
Spring
-
springboot spring 读取配置的几种方式
背景
想读取一下配置文件,这里整理一下一共几种方式。
Spring Boot 中读取配置文件有以下 5 种方法:
使用 @Value 读取配置文件。
使用 @ConfigurationProperties 读取配置文件。
使用 Environment 读取配置文件。
使用 @PropertySource 读取配...
2023-08-02 00:00:00 |
Spring
-
spring mvc interceptor 两种配置方式:xml 文件和 java 类注解
SpringMVC 自定义拦截器
简介
Spring MVC也可以使用拦截器对请求进行拦截处理,用户可以自定义拦截器来实现特定的功能,自定义的拦截器必须实现HandlerInterceptor接口
– preHandle():这个方法在业务处理器处理请求之前被调用,在该方法中对用户请求 request 进行处理。如果程序员决定该拦截器对 请求进行拦截处理后还要调用其他的拦截器,或者是业...
2023-08-02 00:00:00 |
Spring
-
spring 如何动态注入 Bean,根据开关动态指定
业务背景
写了基于 aop 切面的统一组件,因为有些切面的涉及点比较多,有些客户端的写法不够规范。
比如 final,或者用户自定义注解增强之后无法获取。
1)希望用户可以动态指定 aop 等注入类信息
2)希望根据条件,比如是否存在 class 动态配置
动态注册bean的两种api
Spring中的bean定义都保存在 BeanDefinitionRegistry 接口中,单...
2023-08-02 00:00:00 |
Spring
-
spring 增强之后无法获取自定义注解属性及解决方案
场景
为了便于后期代码拓展,在代码中定义了一些注解,统一处理逻辑。
后来有开发同事反应,使用了一下 @Transactional 注解之后,注解直接无效了。
问题演示
为了演示整个过程,我们从最简单的简化版本开始。
注解定义
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interfac...
2023-08-02 00:00:00 |
Spring
-
spring-01-spring 如何直接对一个类进行增强?让其实现新的接口 @DeclareParents
背景
想对 runnable 这些类进行增强。
@DeclareParents的作用
@DeclareParents注解是spring AOP(切面)功能提供一种组件,它可以在代理目标类上增加新的行为(新增新的方法)。
可能你看到这里会有点蒙,没关系我们看下面的栗子,应该就清楚明白了。
@DeclareParents的应用demo
首先我们先通过一张图简单的理解一下,@Decla...
2023-08-02 00:00:00 |
Spring