Springboot 实现注解的参数值可以动态设置 |
您所在的位置:网站首页 › compensable注解属性 › Springboot 实现注解的参数值可以动态设置 |
一般来说,注解只能配置常量,在一些构架的开发中,有时候我们需要给注解动态配置一些值,或者想从配置文件中读取配置。直接在注解上配置是无法实现的,但是我们可以在拿到注解的值之后,再对这些值进行另外的操作。比如在注解上面配置占位符,在使用的时候,再对这些占位符进行替换。这一块其实 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();如图: 新增一行代码 作者:永恒不变的是变 来源链接: https://www.toutiao.com/a6963521962589045261/?log_from=88cda9d0b1def_1621403335016&wid=1623062869936 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |