一般来说,注解只能配置常量,在一些构架的开发中,有时候我们需要给注解动态配置一些值,或者想从配置文件中读取配置。直接在注解上配置是无法实现的,但是我们可以在拿到注解的值之后,再对这些值进行另外的操作。比如在注解上面配置占位符,在使用的时候,再对这些占位符进行替换。这一块其实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-------->类上动态参数设置
如图:
控制台输出
说明已经获取到配置文件的值,此时,我们通过访问接口:
http://127.0.0.1:8081/xxService/api/save
看一下是否能访问,目的是为了确认类上的注解是否动态设置值成功。
postman请求测试结果
控制台打印
可以看到,确实请求成功了,说明类上的注解动态参数设置确实是成功了。
二、方法上的注解动态参数设置
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-------->方法上动态参数设置
如图:
控制台打印
说明已经获取到配置文件的值,此时,我们通过访问接口:
http://127.0.0.1:8081/xxService/api/save
看一下是否能访问,目的是为了确认方法上的注解是否动态设置参数值成功。
postman请求测试
可以看到,确实请求成功了,说明类上的注解动态参数值设置确实是成功了。
三、特殊情况
如果遇到按照上面代码,最后没有效果的情况,可以加一行代码:
// 新增一行代码
mapping.consumes();
如图:
新增一行代码