persistence.xml 从 .properties 文件导入数据库参数值
Posted
技术标签:
【中文标题】persistence.xml 从 .properties 文件导入数据库参数值【英文标题】:persistence.xml to import database parameters values from .properties file 【发布时间】:2013-10-10 20:11:15 【问题描述】:编辑:not duplicate but almost
我想让我的应用程序 persistence.xml 类似于
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
version="1.0">
<persistence-unit name="appName" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.dialect" value="$db.dialect'"/>
<property name="javax.persistence.jdbc.driver" value="$db.driver"/>
<property name="javax.persistence.jdbc.user" value="$db.user"/>
<property name="javax.persistence.jdbc.password" value="$db.password"/>
<property name="javax.persistence.jdbc.url" value="$db.url"/>
</properties>
</persistence-unit>
</persistence>
从我的源文件夹中某处的简单文本文件中获取这些占位符值。
我了解到在使用 Spring 时可能会这样做
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<value>classpath:com/foo/jdbc.properties</value>
</property>
</bean>
但这里我们没有使用 Spring,只使用 Hibernate 和一些 Primefaces。
有可能吗?
谢谢!
编辑:我没有提到一些事情,但作为参考,我也在使用 Shiro Security 和 Ant 来做一些事情。我将发布解决方案作为答案。这使我的项目有 3 个带有数据库参数的不同文件:
persistence.xml(休眠) context.xml (Shiro) database.properties(用于 Ant 中的 Flyway 任务)【问题讨论】:
【参考方案1】:您可以在标准属性文件 (key=value) 中定义它们,并将 Properties
对象传递给 createEntityManagerFactory()
方法,而不是在 persistence.xml
中定义属性,例如:
Properties props = new Properties();
props.load(new FileInputStream("/some/path/persistence.properties"));
EntityManagerFactory factory = Persistence.createEntityManagerFactory("appName", props);
【讨论】:
顺便提一下,如果我还没有找到我的解决方案,我肯定会使用这个。 只是一个提醒。在属性文件中,请记住使用完整的属性名称,例如“javax.persistence.jdbc.user”,而不仅仅是“用户” 为什么我以前没有发现这个【参考方案2】:如果您使用 Maven 作为构建系统,您可以使用 Maven 过滤器在构建期间替换值。
或者你可以写一个简单的属性占位符替换(spring本身内部使用的)
参考:https://***.com/a/14724719/477435
【讨论】:
其实我们是用Ant来构建的。抱歉,但我想我误解了...您是否建议使用 Java 类将值放在某些占位符上? 我实际上是指使用一个 Java 类,它可以通过从属性文件中读取来替换占位符值。但是他下面的答案建议在您可以消除使用persistence.xml而只使用属性文件的地方要好得多。【参考方案3】:我编辑提到我正在使用 Shiro Security,这也需要一些数据库参数。我让它只需要 1 个数据库参数位置,将它们保留在 context.xml 中并在其他位置引用它。
1) Ant 读取 context.xml
Context.xml 有
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<!-- Other stuff... -->
<!-- Shiro's -->
<Resource name="jdbc/postgres" auth="Container"
type="javax.sql.DataSource" driverClassName="org.postgresql.Driver"
url="jdbc:postgresql://url-to-db/database"
username="user" password="pass" />
</Context>
在 Ant build.xml 中使用过
<xmlproperty file="/path/to/context.xml" keepRoot="false" semanticAttributes="true" includeSemanticAttribute="true" />
然后使用
访问它<target name="init-flyway">
<property name="flyway.url" value="$Resource.url" />
<property name="flyway.user" value="$Resource.username" />
<property name="flyway.password" value="$Resource.password" />
<!-- stuff stuff stuff -->
</target>
2) persistence.xml 读取 context.xml
可以使用this 使用上下文的数据存储
<non-jta-data-source>java:/comp/env/jdbc/postgres</non-jta-data-source>
所以,我将 3 个数据库参数删除为 1 个。
感谢您的帮助!
【讨论】:
以上是关于persistence.xml 从 .properties 文件导入数据库参数值的主要内容,如果未能解决你的问题,请参考以下文章