有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java为什么我们必须在持久性中提供数据库凭据。xml

我们正在使用JPA 2.0,我们在websphere中创建了数据源,并试图通过J2SE应用程序访问数据库。我们收到无效的用户名和密码错误。如果我们在persistence.xml中给出用户名和密码,就可以了

请任何人向我解释为什么我们必须持续提供DB凭证。xml,因为我们有数据源

注意:数据源创建成功,测试成功

坚持。xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
      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">

      <persistence-unit name="Printer">

            <jta-data-source>jdbc/TestDataSource</jta-data-source>

            <properties>
                  <property name="openjpa.Optimistic" value="false" />
                  <property name="openjpa.LockManager" value="pessimistic" />
                  <property name="javax.persistence.jdbc.user" value="admin" />
                  <property name="javax.persistence.jdbc.password" value="admin#2" />
                </properties>

      </persistence-unit>
</persistence>

共 (2) 个答案

  1. # 1 楼答案

    在websphere中,似乎没有正确配置数据源Test the database connection通过websphere控制台验证配置

    ADataSource有两种方法来获得AConnection。如果您通过属性提供凭据,那么您的jpa实现似乎会使用DataSource.getConnection(String username, String password)

    连接属性旨在用于JavaSE环境。在JEE中,您应该更喜欢JNDI查找。参见JPA2.0规范的第8.2.1.9

  2. # 2 楼答案

    您不需要在应用程序中指定凭据。只需通过JNDI访问数据库,指定您在WS中创建的数据源的名称

    一种方法是使用预配置的数据源配置持久化单元(请仔细检查它是否配置正确-测试功能在WS中可用)

    <persistence-unit name="default" transaction-type="JTA">
        <provider>
            oracle.toplink.essentials.PersistenceProvider
        </provider>
        <jta-data-source>
            jdbc/MyDataSource
        </jta-data-source>
        <properties>
            <property name="toplink.logging.level" value="INFO"/>
        </properties>
    </persistence-unit>
    

    如果数据源没有在应用程序容器端配置,您可以自己在应用程序端进行设置。例如,您需要许多应用程序,每个应用程序都有自己的数据库连接配置

    <persistence-unit name="default" transaction-type="RESOURCE_LOCAL">
        <provider>
            oracle.toplink.essentials.PersistenceProvider
        </provider>
        <exclude-unlisted-classes>false</exclude-unlisted-classes>
        <properties>
            <property name="toplink.logging.level" value="INFO"/>
            <property name="toplink.jdbc.driver" value="oracle.jdbc.OracleDriver"/>
            <property name="toplink.jdbc.url" value="jdbc:oracle:thin:@myhost:l521:MYSID"/>
            <property name="toplink.jdbc.password" value="tiger"/>
            <property name="toplink.jdbc.user" value="scott"/>
        </properties>
    </persistence-unit>
    

    你的坚持。xml具有两种方式的配置。请删除不必要的代码,然后重试