springmvc 动态设置数据库,国际化内容的显示

本文主要是介绍springmvc 动态设置数据库,国际化内容的显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

国际化配置都是针对静态内容的变换,如果想要数据库的内容也要多语言显示,那可以设置多个数据库,每个数据库存一种语言的内容,显示时只要连接不同的数据库就可以进行多语言的切换显示。上一篇文章介绍了静态内容的国际化显示,本文在上一篇(http://blog.csdn.net/u011489887/article/details/77498775)的基础上进行扩展。

废话不多说直接上干货。

1 jdbc.properties文件内容

mysql.jdbc.driver_class=com.mysql.jdbc.Driver
mysql.jdbc.connection.url=jdbc:mysql://localhost:3306/my_db?useUnicode=true&characterEncoding=utf8
mysql.jdbc.connection.username=yang
mysql.jdbc.connection.password=123456mysql.jdbc.driver_class-en=com.mysql.jdbc.Driver
mysql.jdbc.connection.url-en=jdbc:mysql://localhost:3306/my_com?useUnicode=true&characterEncoding=utf8
mysql.jdbc.connection.username-en=yang
mysql.jdbc.connection.password-en=123456
2.applicationContext.xml文件配置

<bean id="config"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="locations"><list><value>classpath:jdbc.properties</value></list></property></bean><bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <!-- 数据库1 --><property name="driverClassName" value="${mysql.jdbc.driver_class}"/><property name="url" value="${mysql.jdbc.connection.url}"/><property name="username" value="${mysql.jdbc.connection.username}"/><property name="password" value="${mysql.jdbc.connection.password}"/></bean><bean id="dataSource-en" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <!-- 数据库2 -->
<property name="driverClassName" value="${mysql.jdbc.driver_class-en}"/><property name="url" value="${mysql.jdbc.connection.url-en}"/><property name="username" value="${mysql.jdbc.connection.username-en}"/><property name="password" value="${mysql.jdbc.connection.password-en}"/></bean><bean name="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><constructor-arg><ref bean= "ds"/></constructor-arg></bean><bean id="ds" class="dynamicsource.DynamicDataSource"><property name="targetDataSources">    <!-- 动态配置数据库-->
<map key-type="java.lang.String"> <entry key="zh" value-ref="dataSource" /><entry key="en" value-ref="dataSource-en" /></map></property><property name="defaultTargetDataSource" ref="dataSource" /></bean>  
3.实现动态配置数据库的DynamicDataSource.java类

public class DynamicDataSource extends AbstractRoutingDataSource {  private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();  /** *  * @return the currentLookupKey */  public static String getCurrentLookupKey() {  return (String) contextHolder.get();  }  /** *  *            the currentLookupKey to set */  public static void setCurrentLookupKey(String currentLookupKey) {  contextHolder.set(currentLookupKey);  }  /* * (non-Javadoc) *  * @see * org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource# * determineCurrentLookupKey() */  @Override  protected Object determineCurrentLookupKey() {  return getCurrentLookupKey();  }  }  
4.设置一个拦截器在请求要显示的内容前设置数据库源,关键代码如下

 Locale locale = RequestContextUtils.getLocaleResolver(request) .resolveLocale(request); //得到当前显示资源文件的名字
 DynamicDataSource.setCurrentLookupKey(locale.getLanguage()); //设置数据库源





这篇关于springmvc 动态设置数据库,国际化内容的显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1046189

相关文章

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录