JDBC Oracle Swallet ConnectionJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 JDBC Oracle Swallet Connection

Сообщение Anonymous »

Я сталкиваюсь с проблемой, связанной с приложением Java к базе данных Oracle, используя Oracle Wallet в качестве хранилища паролей. < /p>

Чтобы изолировать проблему, я сделал небольшой основной класс следующим образом: < /p>

public static void main(String[] args) {
Connection conn;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
System.setProperty("oracle.net.tns_admin", "c:\\tns");
OracleDataSource ds = new OracleDataSource();
Properties props = new Properties();
System.setProperty("oracle.net.wallet_location", "c:/wallet2");

ds.setConnectionProperties(props);
ds.setURL("jdbc:oracle:thin:/@XE2");
Provider p;
p = new OraclePKIProvider();
Security.insertProviderAt(p, 3);
conn = ds.getConnection();

} catch (SQLException ex) {
Logger.getLogger(main.class.getName()).log(Level.SEVERE, null, ex);

} catch (ClassNotFoundException ex) {
Logger.getLogger(main.class.getName()).log(Level.SEVERE, null, ex);
}
< /code>

В каталоге C: \ tns I Следующие файлы: < /p>

sqlnet.ora
tnsnames.ora
< /code>

Это список для sqlnet.ora < /p>

SQLNET.AUTHENTICATION_SERVICES = (NTS)
names.directory_path = TNSNAMES
SQLNET.WALLET_OVERRIDE = TRUE
#WALLET_LOCATION = (SOURCE=(METHOD=FILE)METHOD_DATA=(DIRECTORY=c:\wallet))
WALLET_LOCATION = (SOURCE=(METHOD=FILE)(METHOD_DATA=(DIRECTORY=c:/wallet)))
< /code>

Что для tnsnames < /p>

...
XE2 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)
< /code>

В C: \ Wallet2 Существуют следующие файлы: < /p>

cwallet.sso
ewallet.p12
< /code>

Файл был ранее сгенерирован с Orapki, и есть моя запись с именем xe2 с правильными учетными данными. Когда я запускаю код, я получаю следующее исключение < /p>

Could not open wallet. java.io.IOException: Could not open wallet. Check password
< /code>

Включение трассировки Oracle Я вижу эти строки: < /p>

mar 02, 2017 3:57:00 PM oracle.jdbc.driver.DatabaseError findMessage
TRACE_30: Enter: "ORA-17168", java.io.IOException: Could not open wallet. java.io.IOException: Could not open wallet. Check password
mar 02, 2017 3:57:00 PM oracle.jdbc.driver.Message11 msg
TRACE_30: 72B6CBCC Enter: "ORA-17168", java.io.IOException: Could not open wallet. java.io.IOException: Could not open wallet. Check password
mar 02, 2017 3:57:00 PM oracle.jdbc.driver.Message11 msg
TRACE_30: 72B6CBCC Exit [0.066509ms]
< /code>

и < /p>

mar 02, 2017 3:57:00 PM oracle.jdbc.driver.PhysicalConnection getSecretStoreCredentials
GRAVE: Throwing SQLException: 168java.io.IOException: Could not open wallet. java.io.IOException: Could not open wallet. Check password
< /code>

Кто -нибудь может мне помочь?
Спасибо за чтение.
r.

Подробнее здесь: https://stackoverflow.com/questions/425 ... connection
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»