| | |
| | | package com.ltkj.framework.config; |
| | | |
| | | import java.io.FileInputStream; |
| | | import java.io.FileOutputStream; |
| | | import java.io.IOException; |
| | | import java.io.*; |
| | | import java.sql.SQLException; |
| | | import java.util.HashMap; |
| | | import java.util.Map; |
| | | import java.util.Properties; |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.Filter; |
| | | import javax.servlet.FilterChain; |
| | | import javax.servlet.FilterConfig; |
| | | import javax.servlet.ServletException; |
| | | import javax.servlet.ServletRequest; |
| | | import javax.servlet.ServletResponse; |
| | |
| | | import com.ltkj.framework.config.properties.DruidProperties; |
| | | import com.ltkj.framework.datasource.DynamicDataSource; |
| | | import com.ltkj.system.service.ISysConfigService; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; |
| | | import org.springframework.boot.context.properties.ConfigurationProperties; |
| | | import org.springframework.boot.web.servlet.FilterRegistrationBean; |
| | |
| | | * @author ltkj |
| | | */ |
| | | @Configuration |
| | | @Slf4j |
| | | public class DruidConfig { |
| | | |
| | | @Value ("${config.properties}") |
| | | private String url; |
| | | |
| | | @Value ("${config.path}") |
| | | private String path; |
| | | |
| | | |
| | | @Bean |
| | | // @ConfigurationProperties("spring.datasource.druid.master") |
| | |
| | | Properties props = new Properties(); |
| | | try { |
| | | // 从文件中读取配置信息 |
| | | FileInputStream fis = new FileInputStream("D:\\ltkjprojectconf\\config.properties"); |
| | | FileInputStream fis = null; |
| | | try { |
| | | fis = new FileInputStream(url); |
| | | } catch (FileNotFoundException e) { |
| | | log.info("数据库连接文件找不到 系统正在创建!"); |
| | | |
| | | File f = new File(path); |
| | | if(!f.exists()){ |
| | | f.mkdirs(); |
| | | } |
| | | File file = new File(url); |
| | | try { |
| | | FileWriter fileWriter = new FileWriter(file); |
| | | fileWriter.write("ip = 你的主数据库连接ip地址\n"); |
| | | fileWriter.write("prot = 你的主数据库连接端口\n"); |
| | | fileWriter.write("name = 你的主数据库连接名称\n"); |
| | | fileWriter.write("username = 你的主数据库连接用户名\n"); |
| | | fileWriter.write("password = 你的主数据库连接密码\n"); |
| | | fileWriter.write("\n"); |
| | | |
| | | |
| | | fileWriter.write("hisenabled = 是否开启 his 从库数据库连接 (从数据源开关/默认关闭 fales)\n"); |
| | | fileWriter.write("hisip = 你的 his 数据库连接ip地址\n"); |
| | | fileWriter.write("hisprot = 你的 his 数据库连接端口\n"); |
| | | fileWriter.write("hisname = 你的 his 数据库连接名称\n"); |
| | | fileWriter.write("hisusername = 你的 his 数据库连接用户名\n"); |
| | | fileWriter.write("hispassword = 你的 his 数据库连接密码\n"); |
| | | fileWriter.write("\n"); |
| | | |
| | | fileWriter.write("pacsenabled = 是否开启pacs从库数据库连接 (从数据源开关/默认关闭 fales)\n"); |
| | | fileWriter.write("pacsip = 你的pacs数据库连接ip地址\n"); |
| | | fileWriter.write("pacsprot = 你的pacs数据库连接端口\n"); |
| | | fileWriter.write("pacsname = 你的pacs数据库连接名称\n"); |
| | | fileWriter.write("pacsusername = 你的pacs数据库连接用户名\n"); |
| | | fileWriter.write("pacspassword = 你的pacs数据库连接密码\n"); |
| | | fileWriter.write("\n"); |
| | | |
| | | |
| | | fileWriter.write("lisenabled = 是否开启 lis 从库数据库连接 (从数据源开关/默认关闭 fales)\n"); |
| | | fileWriter.write("lisip = 你的 lis 数据库连接ip地址\n"); |
| | | fileWriter.write("lisprot = 你的 lis 数据库连接端口\n"); |
| | | fileWriter.write("lisname = 你的 lis 数据库连接名称\n"); |
| | | fileWriter.write("lisusername = 你的 lis 数据库连接用户名\n"); |
| | | fileWriter.write("lispassword = 你的 lis 数据库连接密码\n"); |
| | | |
| | | |
| | | |
| | | |
| | | fileWriter.close(); |
| | | log.info("数据库连接文件创建成功!"); |
| | | } catch (IOException ioException) { |
| | | log.info("数据库连接文件创建失败 请联系管理员手动创建!"); |
| | | ioException.printStackTrace(); |
| | | } |
| | | e.printStackTrace(); |
| | | } |
| | | props.load(fis); |
| | | fis.close(); |
| | | // 获取属性值并赋值 |
| | | Properties properties = new Properties(); |
| | | // 这里是测试写法,具体的value可以通过请求参数传递过来 |
| | | properties.setProperty("druid.url",props.getProperty("url")); |
| | | properties.setProperty("druid.url","jdbc:mysql://"+props.getProperty("ip")+":"+props.getProperty("prot")+"/"+props.getProperty("name")+"" + |
| | | "?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&allowPublicKeyRetrieval=true"); |
| | | properties.setProperty("druid.username",props.getProperty("username")); |
| | | properties.setProperty("druid.password",props.getProperty("password")); |
| | | dataSource.restart(properties); |
| | | log.info("数据库连接成功!!!"); |
| | | } catch (Exception e) { |
| | | log.info("数据库连接失败 请联系管理员!"); |
| | | e.printStackTrace(); |
| | | } |
| | | return druidProperties.dataSource(dataSource); |
| | | } |
| | | |
| | | @Bean |
| | | @ConfigurationProperties("spring.datasource.druid.slave") |
| | | @ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true") |
| | | public DataSource slaveDataSource(DruidProperties druidProperties) { |
| | | // @ConfigurationProperties("spring.datasource.druid.slavehis") |
| | | // @ConditionalOnProperty(prefix = "spring.datasource.druid.slavehis", name = "enabled", havingValue = "true") |
| | | public DataSource slaveHisDataSource(DruidProperties druidProperties) { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties props = new Properties(); |
| | | try { |
| | | // 从文件中读取配置信息 |
| | | FileInputStream fis = null; |
| | | try { |
| | | fis = new FileInputStream(url); |
| | | } catch (FileNotFoundException e) { |
| | | log.info("数据库连接文件找不到!"); |
| | | } |
| | | props.load(fis); |
| | | fis.close(); |
| | | // 获取属性值并赋值 |
| | | String hisenabled = props.getProperty("hisenabled"); |
| | | if (hisenabled.equals("false")) |
| | | return null; |
| | | String hisdbtype = props.getProperty("hisdbtype"); |
| | | switch (hisdbtype){ |
| | | case "sqlserver": |
| | | dataSource = creatSqlServer(hisenabled, props.getProperty("hisip"),props.getProperty("hisprot"),props.getProperty("hisname"),props.getProperty("hisusername"),props.getProperty("hispassword")); |
| | | break; |
| | | case "mysql": |
| | | dataSource = creatMysql(hisenabled, props.getProperty("hisip"),props.getProperty("hisprot"),props.getProperty("hisname"),props.getProperty("hisusername"),props.getProperty("hispassword")); |
| | | break; |
| | | case "oracle": |
| | | dataSource = creatOracle(hisenabled, props.getProperty("hisip"),props.getProperty("hisprot"),props.getProperty("hisname"),props.getProperty("hisusername"),props.getProperty("hispassword")); |
| | | break; |
| | | default: |
| | | dataSource = creatSqlServer(hisenabled, props.getProperty("hisip"),props.getProperty("hisprot"),props.getProperty("hisname"),props.getProperty("hisusername"),props.getProperty("hispassword")); |
| | | break; |
| | | } |
| | | log.info("his数据库连接成功!!!"); |
| | | } catch (Exception e) { |
| | | log.info("数据库连接失败 请联系管理员!"); |
| | | e.printStackTrace(); |
| | | } |
| | | return druidProperties.dataSource(dataSource); |
| | | } |
| | | |
| | | @Bean |
| | | // @ConfigurationProperties("spring.datasource.druid.slavelis") |
| | | // @ConditionalOnProperty(prefix = "spring.datasource.druid.slavelis", name = "enabled", havingValue = "true") |
| | | public DataSource slaveDataLisSource(DruidProperties druidProperties) { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties props = new Properties(); |
| | | try { |
| | | // 从文件中读取配置信息 |
| | | FileInputStream fis = null; |
| | | try { |
| | | fis = new FileInputStream(url); |
| | | } catch (FileNotFoundException e) { |
| | | log.info("数据库连接文件找不到!"); |
| | | } |
| | | props.load(fis); |
| | | fis.close(); |
| | | String lisenabled = props.getProperty("lisenabled"); |
| | | if (lisenabled.equals("false")) |
| | | return null; |
| | | String lisdbtype = props.getProperty("lisdbtype"); |
| | | switch (lisdbtype){ |
| | | case "sqlserver": |
| | | dataSource = creatSqlServer(lisenabled, props.getProperty("lisip"),props.getProperty("lisprot"),props.getProperty("lisname"),props.getProperty("lisusername"),props.getProperty("lispassword")); |
| | | break; |
| | | case "mysql": |
| | | dataSource = creatMysql(lisenabled, props.getProperty("lisip"),props.getProperty("lisprot"),props.getProperty("lisname"),props.getProperty("lisusername"),props.getProperty("lispassword")); |
| | | break; |
| | | case "oracle": |
| | | dataSource = creatOracle(lisenabled, props.getProperty("lisip"),props.getProperty("lisprot"),props.getProperty("lisname"),props.getProperty("lisusername"),props.getProperty("lispassword")); |
| | | break; |
| | | default: |
| | | dataSource = creatMysql(lisenabled, props.getProperty("lisip"),props.getProperty("lisprot"),props.getProperty("lisname"),props.getProperty("lisusername"),props.getProperty("lispassword")); |
| | | break; |
| | | } |
| | | log.info("Lis数据库连接成功!!!"); |
| | | } catch (Exception e) { |
| | | log.info("数据库连接失败 请联系管理员!"); |
| | | e.printStackTrace(); |
| | | } |
| | | return druidProperties.dataSource(dataSource); |
| | | } |
| | | |
| | | @Bean |
| | | // @ConfigurationProperties("spring.datasource.druid.slavepacs") |
| | | // @ConditionalOnProperty(prefix = "spring.datasource.druid.slavepacs", name = "enabled", havingValue = "true") |
| | | public DataSource slaveDataPacsSource(DruidProperties druidProperties) { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties props = new Properties(); |
| | | try { |
| | | // 从文件中读取配置信息 |
| | | FileInputStream fis = null; |
| | | try { |
| | | fis = new FileInputStream(url); |
| | | } catch (FileNotFoundException e) { |
| | | log.info("数据库连接文件找不到"); |
| | | } |
| | | props.load(fis); |
| | | fis.close(); |
| | | // 这里是测试写法,具体的value可以通过请求参数传递过来 |
| | | String pacsenabled = props.getProperty("pacsenabled"); |
| | | if (pacsenabled.equals("false")) |
| | | return null; |
| | | String pacsdbtype = props.getProperty("pacsdbtype"); |
| | | switch (pacsdbtype){ |
| | | case "sqlserver": |
| | | dataSource = creatSqlServer(pacsenabled, props.getProperty("pacsip"),props.getProperty("pacsprot"),props.getProperty("pacsname"),props.getProperty("pacsusername"),props.getProperty("pacspassword")); |
| | | break; |
| | | case "mysql": |
| | | dataSource = creatMysql(pacsenabled, props.getProperty("pacsip"),props.getProperty("pacsprot"),props.getProperty("pacsname"),props.getProperty("pacsusername"),props.getProperty("pacspassword")); |
| | | break; |
| | | case "oracle": |
| | | dataSource = creatOracle(pacsenabled, props.getProperty("pacsip"),props.getProperty("pacsprot"),props.getProperty("pacsname"),props.getProperty("pacsusername"),props.getProperty("pacspassword")); |
| | | break; |
| | | default: |
| | | dataSource = creatOracle(pacsenabled, props.getProperty("pacsip"),props.getProperty("pacsprot"),props.getProperty("pacsname"),props.getProperty("pacsusername"),props.getProperty("pacspassword")); |
| | | break; |
| | | } |
| | | log.info("数据库连接成功!!!"); |
| | | } catch (Exception e) { |
| | | log.info("数据库连接失败 请联系管理员!"); |
| | | e.printStackTrace(); |
| | | } |
| | | return druidProperties.dataSource(dataSource); |
| | | } |
| | | |
| | | |
| | | @Bean |
| | | // @ConfigurationProperties("spring.datasource.druid.slavepacs") |
| | | // @ConditionalOnProperty(prefix = "spring.datasource.druid.slavepacs", name = "enabled", havingValue = "true") |
| | | public DataSource slaveDataWsSource(DruidProperties druidProperties) { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties props = new Properties(); |
| | | try { |
| | | // 从文件中读取配置信息 |
| | | FileInputStream fis = null; |
| | | try { |
| | | fis = new FileInputStream(url); |
| | | } catch (FileNotFoundException e) { |
| | | log.info("数据库连接文件找不到"); |
| | | } |
| | | props.load(fis); |
| | | fis.close(); |
| | | // 这里是测试写法,具体的value可以通过请求参数传递过来 |
| | | String pacsenabled = props.getProperty("pacsenabled"); |
| | | if (pacsenabled.equals("false")) |
| | | return null; |
| | | String pacsdbtype = props.getProperty("wsdbtype"); |
| | | switch (pacsdbtype){ |
| | | case "sqlserver": |
| | | dataSource = creatSqlServer(pacsenabled, props.getProperty("wsip"),props.getProperty("wsprot"), |
| | | props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); |
| | | break; |
| | | case "mysql": |
| | | dataSource = creatMysql(pacsenabled, props.getProperty("wsip"), |
| | | props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); |
| | | break; |
| | | case "oracle": |
| | | dataSource = creatOracle(pacsenabled, props.getProperty("wsip"), |
| | | props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername"),props.getProperty("wspassword")); |
| | | break; |
| | | default: |
| | | dataSource = creatOracle(pacsenabled, props.getProperty("wsip"),props.getProperty("wsprot"),props.getProperty("wsname"),props.getProperty("wsusername") |
| | | ,props.getProperty("wspassword")); |
| | | break; |
| | | } |
| | | log.info("数据库连接成功!!!"); |
| | | } catch (Exception e) { |
| | | log.info("数据库连接失败 请联系管理员!"); |
| | | e.printStackTrace(); |
| | | } |
| | | return druidProperties.dataSource(dataSource); |
| | | } |
| | | |
| | | |
| | | private DruidDataSource creatSqlServer(String enabled, String ip,String port,String db,String user,String password) throws SQLException { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties properties = new Properties(); |
| | | properties.setProperty("druid.enabled", enabled); |
| | | properties.setProperty("druid.driverClassName","com.microsoft.sqlserver.jdbc.SQLServerDriver"); |
| | | properties.setProperty("druid.url","jdbc:sqlserver://"+ ip+":"+ port+";DatabaseName="+ db+ |
| | | ";encrypt=true;trustServerCertificate=true;sslProtocol=TLSv1.2;"); |
| | | properties.setProperty("druid.username", user); |
| | | properties.setProperty("druid.password", password); |
| | | dataSource.restart(properties); |
| | | return dataSource; |
| | | } |
| | | |
| | | private DruidDataSource creatMysql(String enabled, String ip,String port,String db,String user,String password) throws SQLException { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties properties = new Properties(); |
| | | properties.setProperty("druid.enabled",enabled); |
| | | properties.setProperty("druid.url","jdbc:mysql://"+ip+":"+port+"/"+db+"" + |
| | | "?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8"); |
| | | properties.setProperty("druid.username",user); |
| | | properties.setProperty("druid.password",password); |
| | | dataSource.restart(properties); |
| | | return dataSource; |
| | | } |
| | | |
| | | private DruidDataSource creatOracle(String enabled, String ip,String port,String db,String user,String password) throws SQLException { |
| | | DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); |
| | | Properties properties = new Properties(); |
| | | properties.setProperty("druid.enabled",enabled); |
| | | properties.setProperty("druid.driverClassName","oracle.jdbc.OracleDriver"); |
| | | properties.setProperty("druid.url","jdbc:oracle:thin:@//"+ip+"/"+db); |
| | | properties.setProperty("druid.username",user); |
| | | properties.setProperty("druid.password",password); |
| | | dataSource.restart(properties); |
| | | return dataSource; |
| | | } |
| | | |
| | | |
| | | @Bean(name = "dynamicDataSource") |
| | | @Primary |
| | | public DynamicDataSource dataSource(DataSource masterDataSource) { |
| | | Map<Object, Object> targetDataSources = new HashMap<>(); |
| | | targetDataSources.put(DataSourceType.MASTER.name(), masterDataSource); |
| | | setDataSource(targetDataSources, DataSourceType.SLAVE.name(), "slaveDataSource"); |
| | | setDataSource(targetDataSources, DataSourceType.SLAVE_HIS.name(), "slaveHisDataSource"); |
| | | setDataSource(targetDataSources, DataSourceType.SLAVE_LIS.name(), "slaveDataLisSource"); |
| | | setDataSource(targetDataSources, DataSourceType.SLAVE_PACS.name(), "slaveDataPacsSource"); |
| | | setDataSource(targetDataSources, DataSourceType.SLAVE_WS.name(), "slaveDataWsSource"); |
| | | return new DynamicDataSource(masterDataSource, targetDataSources); |
| | | } |
| | | |
| | |
| | | // 创建filter进行过滤 |
| | | Filter filter = new Filter() { |
| | | @Override |
| | | public void init(javax.servlet.FilterConfig filterConfig) throws ServletException { |
| | | public void init(FilterConfig filterConfig) throws ServletException { |
| | | } |
| | | |
| | | @Override |