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

个人网站经营 合法么网站建设有什么注意

个人网站经营 合法么,网站建设有什么注意,linux做网站服务器吗,企业展厅的设计公司价格背景 随着互联网应用的快速发展#xff0c;多数据源的需求日益增多。Spring Boot 以其简洁的配置和强大的功能#xff0c;成为实现动态数据源切换的理想选择。本文将通过具体的配置和代码示例#xff0c;详细介绍如何在 Spring Boot 应用中实现动态数据源切换#xff0c;帮…背景 随着互联网应用的快速发展多数据源的需求日益增多。Spring Boot 以其简洁的配置和强大的功能成为实现动态数据源切换的理想选择。本文将通过具体的配置和代码示例详细介绍如何在 Spring Boot 应用中实现动态数据源切换帮助开发者高效应对不同业务场景下的数据管理需求。无论是读写分离还是数据隔离都能轻松搞定。 AOP动态代理 AOP注解 Target({ElementType.METHOD, ElementType.TYPE}) Retention(RetentionPolicy.RUNTIME) public interface TargetDataSource {String name(); } AOP切面类 Aspect Component public class DataSourceAspect {Pointcut(annotation(com.example.aliyunai.db.TargetDataSource))public void dataSourcePointcut() {}Before(dataSourcePointcut())public void changeDataSource(JoinPoint point) {MethodSignature signature (MethodSignature) point.getSignature();Method method signature.getMethod();TargetDataSource targetDataSource method.getAnnotation(TargetDataSource.class);if (targetDataSource ! null) {String dataSourceName targetDataSource.name();DataSourceContextHolder.setDataSourceKey(dataSourceName);}}After(dataSourcePointcut())public void clearDataSource(JoinPoint point) {DataSourceContextHolder.clearDataSourceKey();} } 数据源配置 Configuration public class DataSourceConfig {Bean(name master)public DataSource primaryDataSource() {return DataSourceBuilder.create().type(HikariDataSource.class).driverClassName().url().username().password().build();}Bean(name slave)public DataSource secondaryDataSource() {return DataSourceBuilder.create().type(HikariDataSource.class).driverClassName().url().username().password().build();}Bean(name dynamicDataSource)Primarypublic DynamicDataSource dynamicDataSource(Qualifier(master) DataSource master,Qualifier(slave) DataSource slave) {MapObject, Object targetDataSources new HashMap();targetDataSources.put(master, master);targetDataSources.put(slave, slave);DynamicDataSource dynamicDataSource new DynamicDataSource();dynamicDataSource.setTargetDataSources(targetDataSources);dynamicDataSource.setDefaultTargetDataSource(master);return dynamicDataSource;}} 线程上下文 public class DataSourceContextHolder {private static final ThreadLocalString contextHolder new ThreadLocal();public static void setDataSourceKey(String key) {contextHolder.set(key);}public static String getDataSourceKey() {return contextHolder.get();}public static void clearDataSourceKey() {contextHolder.remove();} } 动态数据源设置 public class DynamicDataSource extends AbstractRoutingDataSource {private static final Logger logger LoggerFactory.getLogger(DynamicDataSource.class);Overrideprotected Object determineCurrentLookupKey() {String dataSourceKey DataSourceContextHolder.getDataSourceKey();logger.info(Determining current data source: {}, dataSourceKey);return dataSourceKey;} }service类 Service public class UserService {Resourceprivate UserMapper userMapper;TargetDataSource(name master)public User queryFromPrimary() {User user userMapper.selectById(1);return user;}TargetDataSource(name slave)public User queryFromSecondary() {User user userMapper.selectById(1L);return user;} } Mybatis 拦截器 Component Intercepts({Signature(type Executor.class, method query, args {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class}),Signature(type Executor.class, method update, args {MappedStatement.class,Object.class})}) public class DynamicDataSourceInterceptor implements Interceptor {private static final Logger logger LoggerFactory.getLogger(DynamicDataSourceInterceptor.class);// 假设这里有一个获取当前数据源标识的方法你需要根据实际项目中的实现来替换private String getCurrentDataSourceKey() {// 示例从某个上下文持有者中获取数据源标识这里只是示意实际要替换return DataSourceContextHolder.getDataSourceKey();}Overridepublic Object intercept(Invocation invocation) throws Throwable {MappedStatement mappedStatement (MappedStatement) invocation.getArgs()[0];Object parameter invocation.getArgs()[1];BoundSql boundSql mappedStatement.getBoundSql(parameter);String sql boundSql.getSql();//对单个表进行处理logger.info(sql:sql);String mappedStatementId mappedStatement.getId();//对所有查询进行处理if (mappedStatementId.contains(query)) {String table getTable(sql);if (table.equals(user)){DataSourceContextHolder.setDataSourceKey(getCurrentDataSourceKey());}//增删改}else if (mappedStatementId.contains(update)) {DataSourceContextHolder.setDataSourceKey(getCurrentDataSourceKey());}return invocation.proceed();}Overridepublic Object plugin(Object target) {return Plugin.wrap(target, this);}private static String getTable(String sql) {// 定义正则表达式模式用于匹配 from 和 where 之间的表名Pattern pattern Pattern.compile(FROM\\s(\\w)\\sWHERE);Matcher matcher pattern.matcher(sql);if (matcher.find()) {return matcher.group(1);}return null;} }
http://www.w-s-a.com/news/156167/

相关文章:

  • 石家庄网站建设设计产品设计专业就业前景
  • 网站移动排名做最好最全的命理网站
  • 网站怎么防黑客杭州市做外贸网站的公司
  • 网站推广公司认准乐云seo易语言做网站登录
  • 配色设计网站推荐网站下拉菜单重叠
  • 内容展示型网站特点在北京注册公司需要多少钱
  • h5网站源代码创意设计理念
  • 岳阳网站开发服务推广运营平台
  • 网站开发得多长时间湖南建设人力资源网证书查询
  • 论坛网站开发网络营销是什么时候产生的
  • 帮人做网站赚钱无忧软文网
  • 做网站要不要营业执照重庆网站优化seo公司
  • 学院宣传网站建设简介做网站没灵感
  • 网站建设终稿确认书网站意义学校
  • 3小时网站建设平台专业制作教学课件
  • 曲阜网站建设百度开户现货黄金什么网站可以做直播
  • 比较好的企业建站平台小程序开发外包该注意些什么
  • 建行官网官网网站吗二次元风格wordpress模板
  • 怎样开通自己的网站网址导航哪个主页最好
  • 大良o2o网站建设详情页设计说明怎么写
  • 您与此网站之间建立的连接不安全汽车cms系统是什么意思
  • 有没有做logo的网站企业网站的内容营销
  • 哈尔滨做企业网站怎么做网站自动响应
  • 网站建设硬件和软件技术环境配置签约做网站模板
  • 教育网站建设的素材手机app制作流程
  • 免费行情软件网站大全下载网站备案查询
  • flex网站模板wordpress实时预览
  • 建设银行网站模板为什么企业要建设自己的企业文化
  • 网站建设必知免费手机网站建站系统
  • ssh可以做wap网站么嘉兴seo排名