解决@ConfigurationProperties注解的使用及乱码问题
@ConfigurationProperties
作用:用于获取配置文件中的属性定义并绑定到javaBean属性中
举个栗子:
配置文件
mycar.name=徐昂 mycar.price=18w
定义实体类
package com.maggie.demo.entity; import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Data //生成setget方法 @Component //将此类注册为组件 @ConfigurationProperties(prefix = "mycar",ignoreUnknownFields = true) //配置文件属性读取,读取前缀时mycar的,忽略不存在的字段 public class Car { private String name; private String price; @Override public String toString() { return "Car{" + "name='" + name + '\'' + ", price='" + price + '\'' + '}'; } }
启动类输出验证
package com.maggie.demo; import com.maggie.demo.entity.Car; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.context.ConfigurableApplicationContext; import java.io.IOException; @SpringBootApplication public class DemoApplication { public static void main(String[] args) throws IOException { ConfigurableApplicationContext run = SpringApplication.run(DemoApplication.class, args); Car car = run.getBean(Car.class); System.out.println(car.toString()); } }
输出结果
Car{name='å¾æ˜‚', price='18w'}
产生问题,定义中文时,会产生乱码
解决方法
1,将配置文件换成yml文件,则不会产生乱码问题
mycar: name: '徐昂' price: '18w'
2, 覆盖原文件:org.springframework.boot.env.OriginTrackedPropertiesLoader
将OriginTrackedPropertiesLoader所有代码复制出来,按照包路径建立自己的包和类(包名和类名都必须和原来的一致,不然不生效)
然后找出原来的OriginTrackedPropertiesLoader上的编码片段:
CharacterReader(Resource resource) throws IOException { this.reader = new LineNumberReader(new InputStreamReader(resource.getInputStream(), StandardCharsets.ISO_8859_1)); }
将其改为 : StandardCharsets.UTF_8
CharacterReader(Resource resource) throws IOException { this.reader = new LineNumberReader(new InputStreamReader(resource.getInputStream(), StandardCharsets.UTF_8)); }
重启项目,发现项目中文乱码已经解决
Car{name='徐昂', price='18w'}
3, 自定义配置类
配置类
mycar.name=小汽车 mycar.price=18w
定义实体,添加**@PropertySource**注解,指定字符集取utf-8,并指定读取配置文件的路径。
注意:这种方法只能对自定义的properties文件有效,对于spring boot默认生成的application.properties没有效果
@Data //生成setget方法 @Component //将此类注册为组件 //指定字符集,并且指定读取的配置文件 @PropertySource(encoding = "UTF-8", value = "classpath:car.properties", ignoreResourceNotFound = true) @ConfigurationProperties(prefix = "mycar",ignoreUnknownFields = true) //配置文件属性读取,读取前缀是mycar的 public class Car { private String name; private String price; @Override public String toString() { return "Car{" + "name='" + name + '\'' + ", price='" + price + '\'' + '}'; } }
结果:
Car{name='小汽车', price='18w'}
第二种不推荐写法
@ConfigurationProperties+ @EnableConfigurationProperties
@EnableConfigurationProperties作用:开启组件配置绑定功能,将实体类组件注入到容器中
eg:
mycar.name=小汽车 mycar.price=18w
实体类
package com.maggie.demo.entity; import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Data //生成setget方法 @ConfigurationProperties(prefix = "mycar",ignoreUnknownFields = true) //配置文件属性读取,读取前缀时mycar的,忽略不存在的字段 public class Car { private String name; private String price; @Override public String toString() { return "Car{" + "name='" + name + '\'' + ", price='" + price + '\'' + '}'; } }
配置类
@Configuration //配置类注解 ==配置文件 @EnableConfigurationProperties(Car.class) //开启加载配置类 public class BeansConfiguration { }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Mybatis-Plus或PageHelper多表分页查询总条数不对问题的解决方法
PageHelper 这个插件用了很多次了,今天使用的时候才遇到一个问题,这篇文章主要给大家介绍了关于Mybatis-Plus或PageHelper多表分页查询总条数不对问题的解决方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-08-08Elasticsearch中store field与non-store field的区别说明
这篇文章主要介绍了Elasticsearch中store field与non-store field的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-07-0730w+数据使用RedisTemplate pipeline空指针NullPointerException异常分析
这篇文章主要为大家介绍了30w+数据使用RedisTemplate pipeline空指针NullPointerException异常分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-08-08
最新评论