JBoss 5.0.0.GA origine dati di sicurezza-dominio e login-config.xml
-
19-09-2019 - |
Domanda
L'esecuzione in un problema in cui i nostri origini dati per due DBMS diversi (MS-SQLServer e Informix) non prelevano la configurazione di sicurezza di dominio nel file login-config.xml.
Le nostre origini dati simile a questa:
<datasources>
<local-tx-datasource>
<jndi-name>ourTX</jndi-name>
<connection-url>jdbc:informix-sqli://our.server.com:1526/wlms:informixserver=ol_db</connection-url>
<driver-class>com.informix.jdbc.IfxDriver</driver-class>
<security-domain>ourDS</security-domain>
<!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml (optional) -->
<metadata>
<type-mapping>InformixDB</type-mapping>
</metadata>
<min-pool-size>5</min-pool-size>
<max-pool-size>50</max-pool-size>
<prefill>yes</prefill>
<prepared-statement-cache-size>10</prepared-statement-cache-size>
<idle-timeout-minutes>5</idle-timeout-minutes>
<new-connection-sql>set lock mode to wait 4;set isolation to cursor stability;</new-connection-sql>
<check-valid-connection-sql>SELECT count(*) FROM dummy;</check-valid-connection-sql>
</local-tx-datasource>
</datasources>
E il nostro login-config.xml ha la seguente voce:
<application-policy name="ourDS">
<authentication>
<login-module code="org.jboss.resource.security.SecureIdentityLoginModule" flag="required">
<module-option name="userName">user</module-option>
<module-option name="password">-4e5f8b6c4217c342c03b57ed16d31678</module-option>
<module-option name="managedConnectionFactoryName">jboss.jca:service=LocalTxCM,name=ourTX</module-option>
</login-module>
</authentication>
</application-policy>
Tuttavia, una volta che il server JBoss viene distribuito, otteniamo un errore come questo per Informix:
13:23:13,521 WARN [JBossManagedConnectionPool] Throwable while attempting to get a new connection: null
org.jboss.resource.JBossResourceException: Could not create connection; - nested throwable: (java.sql.SQLException: Incorrect password or user com.informix.asf.IfxASFRemoteException: user@my.computer.com is not known on the database server.)
E per MS-SQLServer otteniamo un errore simile a Informix che assomiglia a:
13:25:23,053 WARN [JBossManagedConnectionPool] Throwable while attempting to get a new connection: null
org.jboss.resource.JBossResourceException: Could not create connection; - nested throwable: (com.microsoft.sqlserver.jdbc.SQLServerException: Login failed for user ''. The user is not associated with a trusted SQL Server connection.)
Ora, se, commentiamo l'elemento di sicurezza di dominio nel file * -ds.xml e sostituirlo con un nome utente semplice e una password di testo in chiaro, sia il lavoro origine dati con entrambi i motori di database. Stiamo usando il 'tutto' configurazione del server in JBoss. Abbiamo fatto in modo che login-config.xml viene sempre caricato all'avvio. E il hqsqldb-ds.xml utilizzando l'elemento di sicurezza-dominio funziona. Ma usando la nostra applicazione aggiunto-politica al login-config.xml, sembra che l'origine dati non ottiene i valori quando si stabilisce una nuova connessione.
Tutte le idee che stiamo facendo di sbagliato? Abbiamo perso qualcosa?
Soluzione
stavamo testando la validità del origine dati tramite l'admin-console. A causa di dove stavamo testando il database, questo è errore nella versione di JBoss EAP 5.0.0.GA. Anche se non confermata, potrebbe anche essere un ma bug nel admin-console per 5.0.1.GA e forse 5.0.2.GA.
Tutto sopra è stato in realtà di lavoro.