DruidConfig.java 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. package com.ruoyi.framework.config;
  2. import java.io.IOException;
  3. import java.util.HashMap;
  4. import java.util.Map;
  5. import javax.servlet.Filter;
  6. import javax.servlet.FilterChain;
  7. import javax.servlet.ServletException;
  8. import javax.servlet.ServletRequest;
  9. import javax.servlet.ServletResponse;
  10. import javax.sql.DataSource;
  11. import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
  12. import org.springframework.boot.context.properties.ConfigurationProperties;
  13. import org.springframework.boot.web.servlet.FilterRegistrationBean;
  14. import org.springframework.context.annotation.Bean;
  15. import org.springframework.context.annotation.Configuration;
  16. import org.springframework.context.annotation.Primary;
  17. import com.alibaba.druid.pool.DruidDataSource;
  18. import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
  19. import com.alibaba.druid.spring.boot.autoconfigure.properties.DruidStatProperties;
  20. import com.alibaba.druid.util.Utils;
  21. import com.ruoyi.common.enums.DataSourceType;
  22. import com.ruoyi.common.utils.spring.SpringUtils;
  23. import com.ruoyi.framework.config.properties.DruidProperties;
  24. import com.ruoyi.framework.datasource.DynamicDataSource;
  25. /**
  26. * druid 配置多数据源
  27. *
  28. * @author ruoyi
  29. */
  30. @Configuration
  31. public class DruidConfig {
  32. @Bean
  33. @ConfigurationProperties("spring.datasource.druid.master")
  34. public DataSource masterDataSource(DruidProperties druidProperties) {
  35. DruidDataSource dataSource = DruidDataSourceBuilder.create().build();
  36. return druidProperties.dataSource(dataSource);
  37. }
  38. @Bean
  39. @ConfigurationProperties("spring.datasource.druid.slave")
  40. @ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true")
  41. public DataSource slaveDataSource(DruidProperties druidProperties) {
  42. DruidDataSource dataSource = DruidDataSourceBuilder.create().build();
  43. return druidProperties.dataSource(dataSource);
  44. }
  45. @Bean(name = "dynamicDataSource")
  46. @Primary
  47. public DynamicDataSource dataSource(DataSource masterDataSource) {
  48. Map<Object, Object> targetDataSources = new HashMap<>();
  49. targetDataSources.put(DataSourceType.MASTER.name(), masterDataSource);
  50. setDataSource(targetDataSources, DataSourceType.SLAVE.name(), "slaveDataSource");
  51. return new DynamicDataSource(masterDataSource, targetDataSources);
  52. }
  53. /**
  54. * 设置数据源
  55. *
  56. * @param targetDataSources 备选数据源集合
  57. * @param sourceName 数据源名称
  58. * @param beanName bean名称
  59. */
  60. public void setDataSource(Map<Object, Object> targetDataSources, String sourceName, String beanName) {
  61. try {
  62. DataSource dataSource = SpringUtils.getBean(beanName);
  63. targetDataSources.put(sourceName, dataSource);
  64. } catch (Exception e) {
  65. }
  66. }
  67. /**
  68. * 去除监控页面底部的广告
  69. */
  70. @SuppressWarnings({"rawtypes", "unchecked"})
  71. @Bean
  72. @ConditionalOnProperty(name = "spring.datasource.druid.statViewServlet.enabled", havingValue = "true")
  73. public FilterRegistrationBean removeDruidFilterRegistrationBean(DruidStatProperties properties) {
  74. // 获取web监控页面的参数
  75. DruidStatProperties.StatViewServlet config = properties.getStatViewServlet();
  76. // 提取common.js的配置路径
  77. String pattern = config.getUrlPattern() != null ? config.getUrlPattern() : "/druid/*";
  78. String commonJsPattern = pattern.replaceAll("\\*", "js/common.js");
  79. final String filePath = "support/http/resources/js/common.js";
  80. // 创建filter进行过滤
  81. Filter filter = new Filter() {
  82. @Override
  83. public void init(javax.servlet.FilterConfig filterConfig) throws ServletException {
  84. }
  85. @Override
  86. public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
  87. throws IOException, ServletException {
  88. chain.doFilter(request, response);
  89. // 重置缓冲区,响应头不会被重置
  90. response.resetBuffer();
  91. // 获取common.js
  92. String text = Utils.readFromResource(filePath);
  93. // 正则替换banner, 除去底部的广告信息
  94. text = text.replaceAll("<a.*?banner\"></a><br/>", "");
  95. text = text.replaceAll("powered.*?shrek.wang</a>", "");
  96. response.getWriter().write(text);
  97. }
  98. @Override
  99. public void destroy() {
  100. }
  101. };
  102. FilterRegistrationBean registrationBean = new FilterRegistrationBean();
  103. registrationBean.setFilter(filter);
  104. registrationBean.addUrlPatterns(commonJsPattern);
  105. return registrationBean;
  106. }
  107. }