1
我使用Guice-JPA模塊和hibernate執行DAO操作。Guice-JPA persistance.xml不從屬性文件中讀取佔位符
在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讀取屬性文件建議模塊,知道它可以在沒有佔位符的情況下正常工作。
謝謝。現在效果很好! – Sammy