一般来说,注解只能配置常量,在一些构架的开发中,有时候我们需要给注解动态配置一些值,或者想从配置文件中读取配置。直接在注解上配置是无法实现的,但是我们可以在拿到注解的值之后,再对这些值进行另外的操作。比如在注解上面配置占位符,在使用的时候,再对这些占位符进行替换。这一块其实SpringBoot已经帮我们实现了,拿来即用就行。

实现方式:

一、动态设置类上的注解值

1.1 准备工作

本地服务端口:8081,工具:IDEA

在application.properties中新增一条配置信息,如:

service.api.url=/xxService/api

1.2 代码如下:

import org.springframework.beans.factory.annotation.Autowired; import org.springframework.core.env.Environment; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.annotation.PostConstruct; /** * @description: * @author: xx * @create: 2021-05-18 14:28:36 **/ @RestController @RequestMapping(value = "${service.api.url}", name = "类上动态参数设置") public class DemoController { @Autowired private Environment environment; /** * 动态设置类上的注解的参数值 * @throws NoSuchMethodException */ @PostConstruct public void init() throws NoSuchMethodException { RequestMapping mapping = this.getClass().getAnnotation(RequestMapping.class); // 获取参数值 String value = environment.resolvePlaceholders(mapping.value()[0]); String name = environment.resolvePlaceholders(mapping.name()); // 输出 System.out.println("value-------->" value); System.out.println("name-------->" name); } /** * 测试方法 */ @PostMapping(value = "save") public void save() { System.out.println("我已经进入save()方法。。。。。。。。。。。"); } }

启动服务,可以看到控制台输出:

value-------->/xxService/api name-------->类上动态参数设置

如图:

springboot动态请求参数(动态设置注解参数值)(1)

控制台输出

说明已经获取到配置文件的值,此时,我们通过访问接口:

http://127.0.0.1:8081/xxService/api/save

看一下是否能访问,目的是为了确认类上的注解是否动态设置值成功。

springboot动态请求参数(动态设置注解参数值)(2)

postman请求测试结果

springboot动态请求参数(动态设置注解参数值)(3)

控制台打印

可以看到,确实请求成功了,说明类上的注解动态参数设置确实是成功了。

二、方法上的注解动态参数设置

2.1 准备工作

在application.properties中新增一条配置信息,如:

service.api.url.method=/save

2.2 代码如下:

import org.springframework.beans.factory.annotation.Autowired; import org.springframework.core.env.Environment; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import javax.annotation.PostConstruct; /** * @description: * @author: xx * @create: 2021-05-18 14:28:36 **/ @RestController @RequestMapping(value = "/xxService/api") public class DemoController { @Autowired private Environment environment; /** * 动态设置方法上的注解的参数值 * @throws NoSuchMethodException */ @PostConstruct public void init() throws NoSuchMethodException { RequestMapping mapping = this.getClass().getMethod("save").getAnnotation(RequestMapping.class); // 获取参数值 String value = environment.resolvePlaceholders(mapping.value()[0]); String name = environment.resolvePlaceholders(mapping.name()); // 输出 System.out.println("value-------->" value); System.out.println("name-------->" name); } /** * 测试方法 */ @RequestMapping(value = "${service.api.url.method}", name = "方法上动态参数设置", method = RequestMethod.POST) public String save() { System.out.println("我已经进入save()方法。。。。。。。。。。。"); return "再次请求成功!"; } }

启动服务,可以看到控制台输出:

value-------->/save name-------->方法上动态参数设置

如图:

springboot动态请求参数(动态设置注解参数值)(4)

控制台打印

说明已经获取到配置文件的值,此时,我们通过访问接口:

http://127.0.0.1:8081/xxService/api/save

看一下是否能访问,目的是为了确认方法上的注解是否动态设置参数值成功。

springboot动态请求参数(动态设置注解参数值)(5)

springboot动态请求参数(动态设置注解参数值)(6)

postman请求测试

可以看到,确实请求成功了,说明类上的注解动态参数值设置确实是成功了。

三、特殊情况

如果遇到按照上面代码,最后没有效果的情况,可以加一行代码:

// 新增一行代码

mapping.consumes();

如图:

springboot动态请求参数(动态设置注解参数值)(7)

新增一行代码

,