gpt4 book ai didi

java - Guice-JPA persistence.xml 不从属性文件中读取占位符

转载 作者:行者123 更新时间:2023-11-29 05:36:51 28 4
gpt4 key购买 nike

我正在使用 Guice-JPA 模块和 hibernate 来执行 DAO 操作。

当在 persistence.xml 中硬编码连接信息时,一切正常。但是当我尝试将属性文件用于连接参数时,persistence.xml 只是将它们视为空字符串,我得到一个异常。

这是我的指导代码和 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 模块读取,知道它在没有占位符的情况下工作正常..

最佳答案

您不能在 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

关于java - Guice-JPA persistence.xml 不从属性文件中读取占位符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19209008/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com