这篇文章主要介绍了解决@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 {
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程学习网。
本文标题为:解决@ConfigurationProperties注解的使用及乱码问题
基础教程推荐
- JDK数组阻塞队列源码深入分析总结 2023-04-18
- java实现多人聊天系统 2023-05-19
- Java文件管理操作的知识点整理 2023-05-19
- Java实现查找文件和替换文件内容 2023-04-06
- ConditionalOnProperty配置swagger不生效问题及解决 2023-01-02
- Java实现线程插队的示例代码 2022-09-03
- java基础知识之FileInputStream流的使用 2023-08-11
- Java数据结构之对象比较详解 2023-03-07
- springboot自定义starter方法及注解实例 2023-03-31
- Java并发编程进阶之线程控制篇 2023-03-07