当前位置: 首页 > news >正文

如何判断网站程序使用asp还是php福建住房和城乡建设厅网站

如何判断网站程序使用asp还是php,福建住房和城乡建设厅网站,网页美工设计培训班,网站 建设阶段SpringBoot整合多数据源#xff0c;动态添加新数据源并切换 1.需求2.创建数据源配置类3.切换数据源4.切换数据源管理类5.使用案例5.AOP切面拦截 1.需求 低代码服务需要给多套系统进行功能配置#xff0c;要求表结构必须生成在对应系统的数据库中#xff0c;所以表结构的生成… SpringBoot整合多数据源动态添加新数据源并切换 1.需求2.创建数据源配置类3.切换数据源4.切换数据源管理类5.使用案例5.AOP切面拦截 1.需求 低代码服务需要给多套系统进行功能配置要求表结构必须生成在对应系统的数据库中所以表结构的生成需要动态的获取目标系统的数据库信息切换当前数据源到目标数据库然后再生成。 2.创建数据源配置类 package com.tyq.datasource.config.datasource;import com.alibaba.druid.pool.DruidDataSource; import com.tyq.datasource.config.Properties; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary;import javax.annotation.Resource; import javax.sql.DataSource; import java.sql.SQLException; import java.util.HashMap; import java.util.Map;/*** 向Spring容器中注入DruidConfiguration** author 谭永强*/ Configuration EnableAutoConfiguration(exclude {DataSourceAutoConfiguration.class}) public class DruidConfiguration {Resourceprivate Properties properties;/*** 数据源(默认)*/public DataSource dataSourceToDefault() {DruidDataSource datasource new DruidDataSource();try {datasource.setQueryTimeout(0);datasource.setUrl(jdbc:oracle:thin:192.168.0.30:1521/test2);datasource.setUsername(SCPS);datasource.setPassword(yldtscps);} catch (SQLException e) {e.printStackTrace();}return datasource;}BeanPrimarypublic DataSource dataSource() {MapObject, Object dataSourceMap new HashMap(2);dataSourceMap.put(default, dataSourceToDefault());DynamicDatasource dynamicDatasource new DynamicDatasource();// 注入目标数据源如果有多个数据源直接加入map即可dynamicDatasource.setTargetDataSources(dataSourceMap);// 注入默认数据源dynamicDatasource.setDefaultTargetDataSource(dataSourceToDefault());return dynamicDatasource;} }3.切换数据源 SpringBoot动态切换数据源主要依靠AbstractRoutingDataSource类这个抽象类中有一个属性为targetDataSources。该属性为Map结构所有需要切换的数据源都存放在其中根据指定的KEY进行切换。 在AbstractRoutingDataSource源码中获取数据库连接是通过this.determineTargetDataSource().getConnection()去获取的而this.determineTargetDataSource()方法中的DataSource则是通过determineCurrentLookupKey()方法返回的key值去前面的dynamicDatasource.setTargetDataSources(dataSourceMap);设置进去的map中查找的。 所以我们需要重写determineCurrentLookupKey()方法如下 package com.tyq.datasource.config.datasource;import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;/*** 动态数据源** author 谭永强* date 2023-08-03*/ public class DynamicDatasource extends AbstractRoutingDataSource {Overrideprotected Object determineCurrentLookupKey() {return DynamicDatasourceHolder.getDataSource();} } 4.切换数据源管理类 数据源属于公共资源考虑到多线程的情况下我们将数据源存储在【ThreadLocal】中保证线程隔离。 package com.tyq.datasource.config.datasource;import java.util.Queue; import java.util.concurrent.ArrayBlockingQueue;/*** 数据源切换管理** author 谭永强* date 2023-08-03*/ public class DynamicDatasourceHolder {/*** 保存数据源的映射*/private final static ThreadLocalString CONTEXT_HOLDER new ThreadLocal();public static String getDataSource() {return CONTEXT_HOLDER.get();}public static void setDataSource(String dataSourceKey) {CONTEXT_HOLDER.set(dataSourceKey);}public static void removeDataSource() {CONTEXT_HOLDER.remove();} }5.使用案例 在Controller中通过DynamicDatasourceHolder指定当前需要使用哪个数据源具体使用如下 RequestMapping(findById) public User findById(String userId) {//指定数据源DynamicDatasourceHolder.setDataSource(default);if (ObjectUtils.isEmpty(userId)) {throw new ParamValidateException(userId不能为空);}User user userService.findById(userId);//移除当前数据源DynamicDatasourceHolder.removeDataSource();return user; }上述案例中已经实现了如果动态切换数据源的过程但是在实际开发中还是太繁琐比如每个接口都必须添加相关切换数据源的代码对代码的侵入性太高下面我们通过AOP的形式去优化切换数据源的过程。 5.AOP切面拦截 通过AOP切面对方法的前置和后置做切换数据源的操作这样就降低了与业务代码耦合、 !--AOP-- dependencygroupIdorg.aspectj/groupIdartifactIdaspectjweaver/artifactIdversion1.9.6/version /dependency注意如果项目中无法导入Aspect则需要添加上述依赖。 package com.tyq.datasource.aop;import com.alibaba.druid.pool.DruidDataSource; import com.tyq.datasource.config.Properties; import com.tyq.datasource.config.datasource.DynamicDatasource; import com.tyq.datasource.config.datasource.DynamicDatasourceHolder; import com.tyq.datasource.config.exception.ParamValidateException; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.springframework.stereotype.Component; import org.springframework.util.ObjectUtils; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes;import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.sql.DataSource; import java.sql.SQLException; import java.util.HashMap; import java.util.Map;/*** 动态数据源切换AOP** author 谭永强* date 2023-08-03*/ Aspect Component public class DynamicDatasourceAop {Autowiredprotected ApplicationContext applicationContext;Resourceprivate Properties properties;/*** 定义切点*/Pointcut(execution (* com.tyq.datasource.controller.*.*(..)))public void pointcut() {}/*** 前置处理*/Before(value pointcut())public void beforeAdvice() {// 接收到请求记录请求内容ServletRequestAttributes attributes (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();if (ObjectUtils.isEmpty(attributes)) {return;}HttpServletRequest request attributes.getRequest();String dataSourceKey request.getParameter(dataSourceKey);if (ObjectUtils.isEmpty(dataSourceKey)) {throw new ParamValidateException(dataSourceKey不能为空!);}//获取当前动态数据源DynamicDatasource dynamicDatasource applicationContext.getBean(DynamicDatasource.class);//所有已连接的数据源集合MapObject, DataSource resolvedDataSources dynamicDatasource.getResolvedDataSources();if (ObjectUtils.isEmpty(resolvedDataSources.get(dataSourceKey))) {//此处为模拟到数据库中查询数据源信息的过程查询到数据源信息后创建数据源并添加到动态数据源管理中//动态加入新的数据源DataSource dataSource getDataSource();MapObject, Object dataSourceMap new HashMap(resolvedDataSources.size() 1);dataSourceMap.putAll(resolvedDataSources);dataSourceMap.put(three, dataSource);dynamicDatasource.setTargetDataSources(dataSourceMap);}//动态切换数据源DynamicDatasourceHolder.setDataSource(dataSourceKey);}/*** 后置处理*/AfterReturning(value pointcut())public void afterAdvice() {// 接收到请求记录请求内容ServletRequestAttributes attributes (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();if (ObjectUtils.isEmpty(attributes)) {return;}HttpServletRequest request attributes.getRequest();String dataSourceKey request.getParameter(dataSourceKey);if (ObjectUtils.isEmpty(dataSourceKey)) {throw new ParamValidateException(dataSourceKey不能为空!);}System.out.println(后置处理: dataSourceKey);//删除当前数据源DynamicDatasourceHolder.removeDataSource();}/*** 模拟成功查询到数据源并创建DataSource** return 数据源*/public DataSource getDataSource() {DruidDataSource datasource new DruidDataSource();try {datasource.setQueryTimeout(0);datasource.setUrl(jdbc:oracle:thin:192.168.0.59:1526/qstest);datasource.setUsername(SCPS);datasource.setPassword(yldtscps);} catch (SQLException e) {e.printStackTrace();}return datasource;} }
http://www.hkea.cn/news/14426977/

相关文章:

  • 餐饮网站建设优化建站外国优秀网站
  • 做公司网站详细步骤6wordpress添加内容
  • 购物网站有哪些平台dw如何做商业网站
  • 网站开发 都包含什么语言黑龙江省建设工程网
  • 莱州网站建设费用wordpress 电子商务主题
  • 教做鞋的网站网站空间服务器费用
  • 网站建设的布局平安银行官方网站
  • 长春网站网站网站代理怎么做
  • 做的最成功的个人网站十大设计创意产品网站
  • 小木桥路建设工程招投标网站wordpress 只有英文版
  • 网站开发商外包品牌推广互联网广告
  • 做彩票网站收费标准山西中考考生网上服务平台
  • 工信部2017网站备案有服务器有域名怎么做网站
  • 做公司中文网站需要注意什么北京最贵商场
  • 宁波淘宝网站建设openwrt wordpress
  • 电子商务网站建设与维护 论文小欢喜林磊儿什么网站做家教
  • wp网站系统模板望野原文翻译
  • 东莞响应式网站哪家好discuz网站同步
  • 漂亮的网站框架浙江建设网
  • 做文创的网站wordpress 模板代码
  • 廊坊网站建设搭建免费低代码管理系统开发
  • 徐州免费建站建设网站了还能消除吗
  • 网站改版开发公司wordpress的运用
  • 外国人做的篆字网站遵义你想网
  • 做面包网站免费网络推广的方法
  • 怎么建设推广网站重庆今天新闻事件
  • 长春建站模板制作wordpress鼠标滑过几何线条
  • 网站建设企西部数码网站打不开
  • 一级a做爰片免费观看网站简单的网站设计
  • 营销网站的推广成都最好的网站建设公司