我使用带有hibernate的Guice-JPA模块来执行DAO操作。
在persistence.xml中对连接信息进行硬编码时,一切正常。但是当我尝试使用属性文件作为连接参数时,persistence.xml只将它们视为空字符串,我得到一个例外。
这是我的guice代码和Persistense.xml。
JpaPersistModule jpaModule = new JpaPersistModule("myModule");
Properties properties = new Properties();
try {
properties.load(Bootstrap.class.getClassLoader().getResourceAsStream("appConfig.properties"));
} catch (IOException e) {
e.printStackTrace();
}
JpaPersistModule module = jpaModule.properties(properties);
injector = Guice.createInjector(new ApplicationConfig(), module);
PersistService persistService = injector.getInstance(PersistService.class);
persistService.start();
在此代码之后,我从调试器确认属性对象包含所有属性,因此我确信它正确读取了属性文件。
这是属性文件和persistence.xml
hibernate.username=root
<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_2_0.xsd"
version="2.0">
<persistence-unit name="24x7monitoring" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.show_sql" value="false" />
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost/dbname"/>
<property name="javax.persistence.jdbc.user" value="${hibernate.username}" />
<property name="javax.persistence.jdbc.password" value="" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
<property name="hibernate.hbm2ddl.auto" value="update"/>
</properties>
</persistence-unit>
我得到以下异常:
Access denied for user ''@'localhost' to database
请告知JPA模块没有读取属性文件的原因,知道它没有占位符就能正常工作..
答案 0 :(得分:3)
您无法在persistence.xml
中使用占位符或替换变量,就像您尝试的那样。您传递给JpaPersistModule
的属性对于<property>
中定义persistence.xml
元素具有影响力。
例如,不要在persitence.xml
中使用此行:
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
您可以在*.properties
文件中定义相同的属性:
javax.persistence.jdbc.driver=com.mysql.jdbc.Driver
所以你应该删除这个无效的行:
<property name="javax.persistence.jdbc.user" value="${hibernate.username}" />
并在您的属性文件中添加如下条目:
javax.persistence.jdbc.user=my_username