使用@ConfigurationProperties注解获取为null的解决方法
一、问题描述
通过get方法去取值一直为null。代码如下:
@Component @ConfigurationProperties(prefix = "file") public class ServiceConfig { /** * windows上传路径 */ private static String winUploadPath; public static String getWinUploadPath() { return winUploadPath; } public static void setWinUploadPath(String winUploadPath) { ServiceConfig.winUploadPath = winUploadPath; } }
application.yml配置:
file: winUploadPath: D:/opt/tongue/uploadPath
二、解决过程
过程一
刚开始一直ide弹这个框,以为是这个问题。
然后搜了资料,有的说下面依赖是生成配置元信息,不引入yml文件就失效了
于是引入之后并没有效果
!!
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency>
过程二
不要在application.yml/properties文件中使用camel大小写。尽量用-分割。
我看了一下原生框架的配置,发现人家确实没大小写,于是改了仍然没有用。
过程三(成功解决!)
因为想的是直接获取属性,所以都是设置的static,包括set方法。于是set方法去除掉static后 成功解决。
三、总结
set方法被static 修饰无法获取到值!!!
不过尽量咱们也规范点不要在application当中区分大小写,尽量用- 。
用横杠的话,其实在java文件当中,他是会自动转换的。
我最终改成了这样,发现在java文件当中的winUploadPath属性照样可以读到值。
file: win-upload-path: D:/opt/tongue/uploadPath
到此这篇关于使用@ConfigurationProperties注解获取为null的解决方法的文章就介绍到这了,更多相关@ConfigurationProperties获取为null内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Hadoop+HBase+ZooKeeper分布式集群环境搭建步骤
这篇文章主要介绍了Hadoop+HBase+ZooKeeper分布式集群环境搭建,集群环境至少需要3个节点,1个Master,2个Slave,节点之间局域网连接,可以相互ping通,本文通过实例给大家介绍的非常详细,需要的朋友可以参考下2022-04-04HTTP 415错误-Unsupported media type详解
这篇文章主要介绍了HTTP 415错误-Unsupported media type详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下2021-08-08SpringBoot Pom文件依赖及Starter启动器详细介绍
这篇文章主要介绍了SpringBoot Pom文件的依赖与starter启动器的作用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-09-09Java 使用POI生成带联动下拉框的excel表格实例代码
本文通过实例代码给大家分享Java 使用POI生成带联动下拉框的excel表格,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下吧2017-09-09
最新评论