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

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐