1

DAO操作を実行するために休止状態でGuice-JPAモジュールを使用しています。

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 モジュールによって読み取られない理由についてアドバイスをお願いします。

4

1 に答える 1

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
于 2013-10-06T15:33:22.270 に答える