首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于JDBC Oracle wallet的连接:内存中的Wallet文件夹

基于JDBC Oracle wallet的连接:内存中的Wallet文件夹
EN

Stack Overflow用户
提问于 2019-11-26 20:04:01
回答 3查看 329关注 0票数 6

我希望使用存储在内存中的钱包连接到Oracle数据库,而不是将钱包存储在磁盘上。

我尝试使用Apache Common VFS在内存中读/写文件。钱包被写入内存(为了确保我甚至将钱包文件夹从ram写入我的磁盘)。

代码语言:javascript
复制
properties.put("oracle.net.tns_admin", "ram://my_wallet");
properties.put("oracle.net.wallet_location",
          String.format("(SOURCE=(METHOD=file)(METHOD_DATA=(DIRECTORY=%s)))", "ram://my_wallet"));

当我尝试使用这些属性建立连接时,我得到了错误:

java.sql.SQLRecoverableException: IO Error: could not resolve the connect identifier DB_1222

PS:如果我把钱包放在磁盘上,我的代码就能正常工作。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-11-27 23:08:43

一种解决方法可能是利用操作系统的内存中文件系统支持,因此对于JDBC来说,它看起来像一个普通文件,但操作系统实际上将其存储在内存中。在类Unix系统上,tmpfs将是这样的文件系统:https://en.m.wikipedia.org/wiki/Tmpfs

票数 2
EN

Stack Overflow用户

发布于 2021-04-10 04:29:54

我知道这是一个老问题,但现在您可以将SSLContext设置为OracleDatasource,并让上下文从任何输入流中读取钱包:

代码语言:javascript
复制
        TrustManagerFactory trustManagerFactory =
                TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
        KeyManagerFactory keyManagerFactory =
                KeyManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());

        KeyStore keyStore = KeyStore.getInstance("SSO", new OraclePKIProvider());


        // ** Read wallet in-memory here **
        keyStore.load(new ByteArrayInputStream(your_wallet_in_memory), null);


        keyManagerFactory.init(keyStore, null);
        trustManagerFactory.init(keyStore);

        SSLContext sslContext = SSLContext.getInstance("SSL");
        sslContext.init(
                keyManagerFactory.getKeyManagers(), trustManagerFactory.getTrustManagers(), null);

        Properties info = new Properties();

        info.put(OracleConnection.CONNECTION_PROPERTY_USER_NAME, userName);
        info.put(OracleConnection.CONNECTION_PROPERTY_PASSWORD, userPassword);

        OracleDataSource ods = new OracleDataSource();
        ods.setURL(dbUrl);
        ods.setConnectionProperties(info);
        ods.setSSLContext(sslContext);

我已经发布了一个使用该方法的示例服务,并在下面的代码库中使用不同类型的钱包进行了测试:https://github.com/nomisvai/oracle-in-memory-wallet-samples

票数 1
EN

Stack Overflow用户

发布于 2019-11-27 19:12:05

不幸的是,Oracle JDBC目前不支持从内存中获取钱包。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59050567

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档