0

Websphere Network デプロイメント サーバー 7.0.0.0 をインストールしました。クラスターを構成しました。「JAAS - J2C 認証データ」を使用してこのデータ ソースを ORA_DS と言うデータ ソースを構成しました。「テスト接続」ボタンをクリックして ORA_DS をテストすると、テスト接続は成功します。

Java コードを使用してこのデータ ソースにアクセスしようとすると、問題が発生します。

データソースにアクセスして接続を作成するコードは次のとおりです。

public class DSTester
{
    /**
     * Return the data source.
     * @return the data source
     */
    private DataSource getDataSource()
    {
        DataSource dataSource = null;

        Hashtable<String, String> env = new Hashtable<String, String>();
        env.put(Context.INITIAL_CONTEXT_FACTORY, "com.ibm.websphere.naming.WsnInitialContextFactory");
        env.put(Context.PROVIDER_URL, "iiop://localhost:9811");

        // Retrieve datasource name
        String dataSourceName = "EPLA1";
        if (dataSource == null)
        {
            try
            {
                Context initialContext = new InitialContext(env);
                dataSource = (DataSource) initialContext.lookup(dataSourceName);
            }
            catch (NamingException e1)
            {
                e1.printStackTrace();
                return null;
            }
        }

        return dataSource;
    }

    public static void main(String[] args)
        throws Exception
    {
        DSTester dsTester = new DSTester();
        DataSource ds = dsTester.getDataSource();
        System.out.println(ds);
        System.out.println(ds.getConnection());
    }
}

出力は次のとおりです。

    com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource@17e40be6
Exception in thread "P=792041:O=0:CT" java.sql.SQLException: ORA-01017: invalid username/password; logon denied
DSRA0010E: SQL State = 72000, Error Code = 1,017
    at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70)
    at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:133)
    at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:206)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:455)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:406)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:399)
    at oracle.jdbc.driver.T4CTTIoauthenticate.receiveOauth(T4CTTIoauthenticate.java:799)
    at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:368)
    at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:508)
    at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:203)
    at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:33)
    at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:510)
    at oracle.jdbc.pool.OracleDataSource.getPhysicalConnection(OracleDataSource.java:275)
    at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java:206)
    at oracle.jdbc.pool.OracleConnectionPoolDataSource.getPhysicalConnection(OracleConnectionPoolDataSource.java:139)
    at oracle.jdbc.pool.OracleConnectionPoolDataSource.getPooledConnection(OracleConnectionPoolDataSource.java:88)
    at oracle.jdbc.pool.OracleConnectionPoolDataSource.getPooledConnection(OracleConnectionPoolDataSource.java:70)
    at com.ibm.ws.rsadapter.spi.InternalGenericDataStoreHelper$1.run(InternalGenericDataStoreHelper.java:1175)
    at com.ibm.ws.security.util.AccessController.doPrivileged(AccessController.java:118)
    at com.ibm.ws.rsadapter.spi.InternalGenericDataStoreHelper.getPooledConnection(InternalGenericDataStoreHelper.java:1212)
    at com.ibm.ws.rsadapter.spi.WSRdbDataSource.getPooledConnection(WSRdbDataSource.java:2019)
    at com.ibm.ws.rsadapter.spi.WSManagedConnectionFactoryImpl.createManagedConnection(WSManagedConnectionFactoryImpl.java:1422)
    at com.ibm.ws.rsadapter.spi.WSDefaultConnectionManagerImpl.allocateConnection(WSDefaultConnectionManagerImpl.java:81)
    at com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource.getConnection(WSJdbcDataSource.java:646)
    at com.ibm.ws.rsadapter.jdbc.WSJdbcDataSource.getConnection(WSJdbcDataSource.java:613)
    at com.test.DSTester.main(DSTester.java:70)

交換するとコードは正常に動作します

ds.getConnection()

ds.getConnection("ora_user", "ora_password")

私の問題は、Oracle のログインの詳細を指定せずに接続を取得する必要があることです。

この問題について私を助けてください。手がかりをいただければ幸いです。ありがとう

4

2 に答える 2

0

すべての構成を確認する必要があると思います: 1) アプリケーションはクラスターにデプロイされていますか、それともクラスター メンバーの 1 つだけにデプロイされていますか? 2) JAAS - J2C 認証データ - 範囲は?

場合によっては、すべての WAS 環境を再起動する必要があります。リソース構成のスコープに依存します

構成オプションを改善するために、リソース参照を追加することをお勧めします。IBM Tech noteを参照

于 2013-10-14T03:32:46.643 に答える
0

WAS で実行されているアプリケーションからデータソースを取得すればうまくいくと思います。

サーブレットを作成してみてください。

Context initialContext = new InitialContext();
DataSource dataSource = (DataSource) initialContext.lookup("EPLA1");
Connection con = dataSource.getConnection();

サーブレット内では WAS 内で実行されているため、「テスト接続」が機能する場合は問題ありません。外部で実行することは、おそらく別のコンテキストです。

于 2013-10-05T10:14:43.997 に答える