【问题标题】:Guice-JPA persistance.xml not reading placeholders from properties fileGuice-JPA persistence.xml 没有从属性文件中读取占位符
【发布时间】:2013-10-06 12:46:39
【问题描述】:

我正在使用带有 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 模块没有读取属性文件,因为知道它在没有占位符的情况下可以正常工作..

【问题讨论】:

    标签: java hibernate jpa guice guice-persist


    【解决方案1】:

    您不能像您尝试做的那样在persistence.xml 中使用占位符或替换变量。您传递给JpaPersistModule 的属性是在persistence.xml 中定义&lt;property&gt; 元素的替代方法。

    例如,而不是在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
    

    【讨论】:

      猜你喜欢
      • 2010-12-08
      • 1970-01-01
      • 2017-07-09
      • 1970-01-01
      • 2021-04-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多