如何在spring中读取properties配置文件里面的信息

如何在spring中读取properties配置文件里面的信息,第1张

一个系统中通常会存在如下一些以Properties形式存在的配置文件

1数据库配置文件demo-dbproperties:

2消息服务配置文件demo-mqproperties:

3远程调用的配置文件demo-remoteproperties:

一、系统中需要加载多个Properties配置文件

应用场景:Properties配置文件不止一个,需要在系统启动时同时加载多个Properties文件。

配置方式

<!-- 将多个配置文件读取到容器中,交给Spring管理 -->

我们也可以将配置中的List抽取出来:

<!-- 将多个配置文件位置放到列表中 -->

<!-- 将配置文件读取到容器中,交给Spring管理 -->

二、整合多工程下的多个分散的Properties

应用场景:工程组中有多个配置文件,但是这些配置文件在多个地方使用,所以需要分别加载。

注意:其中order属性代表其加载顺序,而ignoreUnresolvablePlaceholders为是否忽略不可解析的 Placeholder,如配置了多个PropertyPlaceholderConfigurer,则需设置为true。这里一定需要按照这种方式设置这两个参数。

三、Bean中直接注入Properties配置文件中的值

应用场景:Bean中需要直接注入Properties配置文件中的值 。例如下面的代码中需要获取上述demo-remoteproperties中的值:

<!-- 这种加载方式可以在代码中通过@Value注解进行注入,

可以将配置整体赋给Properties类型的类变量,也可以取出其中的一项赋值给String类型的类变量 -->

<!-- <util:properties/> 标签只能加载一个文件,当多个属性文件需要被加载的时候,可以使用多个该标签 -->

<!-- <util:properties/> 标签的实现类是PropertiesFactoryBean,

直接使用该类的bean配置,设置其locations属性可以达到一个和上面一样加载多个配置文件的目的 -->

Client类中使用Annotation如下:

四、Bean中存在Properties类型的类变量

应用场景:当Bean中存在Properties类型的类变量需要以注入的方式初始化

1 配置方式:我们可以用(三)中的配置方式,只是代码中注解修改如下

2 配置方式:也可以使用xml中声明Bean并且注入

<!-- 可以使用如下的方式声明Properties类型的FactoryBean来加载配置文件,这种方式就只能当做Properties属性注入,而不能获其中具体的值 -->

<!-- 远端调用客户端类 -->

上述的各个场景在项目群中特别有用,需要灵活的使用上述各种配置方式。

>

mysql某张表中有一个字段为json格式,假设字段名为properties

{

"ocspeventappend-timestampenable": "true",

"ocspstreamingdatafilterexpression": "id=e4_json",

"ocspeventenable": "true",

"ocspschemafieldnames": "id",

"ocspeventoutputnumPartitions": "0",

"ocspeventjson-formatenable": "true",

"ocspstreamingfieldtranslationenable": "false",

"ocspeventappend-idenable": "false",

"ocspstreamingdatakeys": "id",

"ocspstreamsql": "SELECT id FROM uuu_5dea34758400_oi5xs0rdaf WHERE id=e4_json",

"ocspkafkatopic": "hn_20210216b",

"ocspeventperiod": "{\"period\":\"day\",\"time\":[{\"begin\":{\"d\":\"0\",\"h\":\"03:30:23\"},\"end\":{\"d\":\"0\",\"h\":\"23:20:23\"}}],\"startDate\":\"2021-02-16\",\"endDate\":\"2021-03-28\"}",

"ocspeventperiodSwitch": "true",

"ocspeventoutput": "5d74080d1ac0"

}

现在需要查询ocspstreamsql的值 可以使用json_extract函数。注意如果该key是由点分隔符组成的,则需要用双引号将整个key包起来

select json_extract(properties,'$ "ocspschemafieldnames" ') from COMPONENT where type='EVENT' and id='5dea403ed7c0';

json_keys函数可以用来获取json中所有的key字段

同时 select json_keys (properties) from COMPONENT where type='EVENT' and id='5dea403ed7c0';

package cookie;

import javaioFileInputStream;

import javaioIOException;

import javaioPrintWriter;

import javautilProperties;

import javaxservletServletException;

import javaxservlet>

以上就是关于如何在spring中读取properties配置文件里面的信息全部的内容,包括:如何在spring中读取properties配置文件里面的信息、通过Shell脚本读取properties文件中的参数、Mysql查询json数据特定key的值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9304598.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存