Spring Boot中注入配置文件application.properties中的list 對象參數

例如要注入下列參數:java

dyn.spring.datasources[0].name=branchta
dyn.spring.datasources[0].driverClassName=oracle.jdbc.OracleDriver
dyn.spring.datasources[0].url=jdbc:oracle:thin:@IP:1521:ora11g
dyn.spring.datasources[0].username=scott
dyn.spring.datasources[0].password=tiger
dyn.spring.datasources[1].name=ta4
dyn.spring.datasources[1].driverClassName=oracle.jdbc.OracleDriver
dyn.spring.datasources[1].url=jdbc:oracle:thin:@IP:1521:ora11g
dyn.spring.datasources[1].username=hr
dyn.spring.datasources[1].password=hrspring

這樣,經過結合RootBeanDefinition以及DefaultListableBeanFactory相關接口,就能夠純編程式動態建立bean,而無需修改xml或者配置bean,達到純動態的目的。編程

可是網上的例子彷佛都是注入string類型的list,經測試,只要將datasources包含的類型定義爲public便可,以下:oracle

package com.XX.XXX.datasource;

import java.util.List;

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.PropertySource;

@ConfigurationProperties(prefix="dyn.spring")
@PropertySource("classpath:jrescloud.properties")
public class DynamicDataSourceConfig {
    
    private List<DataSource> datasources;
    
    public static class DataSource {
        private String name;
        private String driverClassName;
        private String url;
        private String username;
        private String password;
        private String maxActive;
        private String maxIdle;
        private String maxWait;
        private String validationQuery;
        private String defaultAutoCommit;
        private String connectionInitSqls;
        
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public String getDriverClassName() {
            return driverClassName;
        }
        public void setDriverClassName(String driverClassName) {
            this.driverClassName = driverClassName;
        }
        public String getUrl() {
            return url;
        }
        public void setUrl(String url) {
            this.url = url;
        }
        public String getUsername() {
            return username;
        }
        public void setUsername(String username) {
            this.username = username;
        }
        public String getPassword() {
            return password;
        }
        public void setPassword(String password) {
            this.password = password;
        }
        public String getMaxActive() {
            return maxActive;
        }
        public void setMaxActive(String maxActive) {
            this.maxActive = maxActive;
        }
        public String getMaxIdle() {
            return maxIdle;
        }
        public void setMaxIdle(String maxIdle) {
            this.maxIdle = maxIdle;
        }
        public String getMaxWait() {
            return maxWait;
        }
        public void setMaxWait(String maxWait) {
            this.maxWait = maxWait;
        }
        public String getValidationQuery() {
            return validationQuery;
        }
        public void setValidationQuery(String validationQuery) {
            this.validationQuery = validationQuery;
        }
        public String getDefaultAutoCommit() {
            return defaultAutoCommit;
        }
        public void setDefaultAutoCommit(String defaultAutoCommit) {
            this.defaultAutoCommit = defaultAutoCommit;
        }
        public String getConnectionInitSqls() {
            return connectionInitSqls;
        }
        public void setConnectionInitSqls(String connectionInitSqls) {
            this.connectionInitSqls = connectionInitSqls;
        }
    }

    public List<DataSource> getDatasources() {
        return datasources;
    }

    public void setDatasources(List<DataSource> datasources) {
        this.datasources = datasources;
    }
}

這樣就能夠注入了。。。。。:)ide

花若怒放,蝶自飛來,你若精彩,幸福開懷!2020年12月11日-18日
相關文章
相關標籤/搜索