spring - 使用 Spring MVC 和 Hibernate 4.2.0.Final 的 Multi-Tenancy Web 应用程序

标签 spring hibernate spring-mvc spring-security multi-tenant

我使用 SpringMVC(3.1.3.RELEASE) 和 Hibernate 4.2.0.Final 开发了一个小型 Web 应用程序。

我正在尝试将其转换为 Multi-Tenancy 应用程序。

其他主题中也涵盖了类似的主题,但我找不到解决我的问题的明确解决方案。

我想要实现的是设计一个网络应用程序,它能够:

  1. 启动时读取数据源配置(包含多个数据源定义的 XML 文件,该文件位于 WAR 文件外部,不是应用程序上下文或 hibernate 配置文件)

  2. 为每个数据源创建一个 session 工厂(考虑到每个数据源都是具有不同架构的数据库)。

  3. 如何将 session 工厂范围设置为 session ? (或者我可以重复使用同一个 session 工厂吗?)。

示例:

 Url for client a - URL: http://project.com/a/login.html
 Url for client b - URL: http://project.com/b/login.html

如果客户端“a”发出请求,则读取数据源配置文件并使用该 XML 文件为客户端“a”创建 session 工厂。

如果客户端“b”发送请求,则将重复相同的过程。

我正在寻找的是,如何在不编辑 Spring 配置文件的情况下实现客户订阅时的数据源创建。它需要自动化。

这是我到目前为止所做的代码。

请有人告诉我,我需要进行哪些修改?

请用一些示例代码给出答案。我对 Spring 和 Hibernate 世界很陌生。

Spring.xml

  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close" p:driverClassName="${jdbc.driverClassName}"

        p:url="${jdbc.databaseurl}" 
p:username="${jdbc.username}" p:password="${jdbc.password}" />

    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="configLocation">
            <value>classpath:hibernate.cfg.xml</value>
        </property>

        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${jdbc.dialect}</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
    </bean>

<bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />

JDBC.properties 文件

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.dialect=org.hibernate.dialect.MySQLDialect
jdbc.databaseurl=jdbc:mysql://localhost:3306/Logistics
jdbc.username=root
jdbc.password=rot@pspl#12

hibernate.cfg.xml 文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
    <mapping class="pepper.logis.organizations.model.Organizaions" />
    <mapping class="pepper.logis.assets.model.Assets" />

</session-factory>
</hibernate-configuration>

谢谢

最佳答案

首先使用tenant_id为租户创建一个表,并将其与所有用户关联。现在,您可以在用户登录时获取此详细信息并在 session 中设置它。

关于spring - 使用 Spring MVC 和 Hibernate 4.2.0.Final 的 Multi-Tenancy Web 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20627972/

相关文章:

ios - 我的 Xcode 应用程序图标项目中出现齿轮图标,我无法再运行它

java - 即使给出了正确的提供程序,也会发生有关 PersistenceProvider 的 Hibernate 警告

java - Spring中HTTP请求是如何解码的?

java - Maven WAR 依赖项 - 无法解析包?

spring - 未找到 REST CXF 和 Spring cxf-extension-jaxrs-binding 文件异常?

sql - 混合隐式和显式 JOIN

java - Spring + hibernate + JPA

java - 如何通过 Spring Security 和 MarkLogic 的 Java 客户端 API 对用户进行身份验证?

java - Spring 文件上传的问题

其余 Controller 参数的 Spring 验证不起作用