11

編集:重複していませんが、ほとんど

アプリのpersistence.xmlを次のようにしたいと思います

<?xml version="1.0" encoding="UTF-8"?>
<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_1_0.xsd"
                version="1.0">
   <persistence-unit name="appName" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <properties>
            <property name="hibernate.dialect" value="${db.dialect'}"/>
            <property name="javax.persistence.jdbc.driver" value="${db.driver}"/>
            <property name="javax.persistence.jdbc.user" value="${db.user}"/>
            <property name="javax.persistence.jdbc.password" value="${db.password}"/>
            <property name="javax.persistence.jdbc.url" value="${db.url}"/>
        </properties>
    </persistence-unit>
</persistence>

ソースフォルダーのどこかにある単純なテキストファイルからこれらのプレースホルダー値を取得します。

Spring を使用すると可能であると読みました

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
        <value>classpath:com/foo/jdbc.properties</value>
    </property>
</bean>

ただし、ここでは Spring を使用せず、Hibernate といくつかの Primefaces のみを使用しています。

出来ますか?

ありがとう!

編集: 言及していないこともありますが、参考までに、Shiro Security と Ant を使用していくつかのことを行っています。解決策を回答として投稿します。これにより、プロジェクトにデータベース パラメーターを含む 3 つの異なるファイルが作成されます。

  • persistence.xml (ハイバネート)
  • context.xml (白)
  • database.properties (Ant の Flyway タスク用)
4

3 に答える 3

1

ビルド システムとして Maven を使用している場合は、ビルド時に Maven フィルターを使用して値を置き換えることができます。

または、単純なプロパティ プレースホルダーの置換を記述することもできます (これは、Spring 自体によって内部的に使用されます)。

参考:https ://stackoverflow.com/a/14724719/477435

于 2013-10-03T23:53:04.267 に答える
1

編集して、Shiro Security を使用していることに言及しました。これには、いくつかのデータベース パラメータも必要です。これらをcontext.xmlにとどめ、他のパラメーターで参照するデータベースパラメーターの場所が1つだけ必要になるようにしました。

1) Ant read context.xml

Context.xml を持つ

<?xml version="1.0" encoding="UTF-8"?>
<Context>
    <!-- Other stuff... -->

    <!-- Shiro's -->
    <Resource name="jdbc/postgres" auth="Container"
        type="javax.sql.DataSource" driverClassName="org.postgresql.Driver"
        url="jdbc:postgresql://url-to-db/database"
        username="user" password="pass" />
</Context>

Ant build.xmlで使用しました

<xmlproperty file="/path/to/context.xml" keepRoot="false" semanticAttributes="true" includeSemanticAttribute="true" />

そして、それを使用してアクセスします

<target name="init-flyway">
    <property name="flyway.url" value="${Resource.url}" />
    <property name="flyway.user" value="${Resource.username}" />
    <property name="flyway.password" value="${Resource.password}" />
    <!-- stuff stuff stuff -->
</target>

2) persistence.xml は context.xml を読み取ります

これを使用してコンテキストのデータストアを使用することが可能です

<non-jta-data-source>java:/comp/env/jdbc/postgres</non-jta-data-source>

そのため、3 つのデータベース パラメータを 1 つだけ削除しました。

助けてくれてありがとう!

于 2013-10-09T00:24:52.997 に答える