当前位置: 首页 > news >正文

Oracle 11g post PSU Oct18 设置ssl连接(使用wallets)

说明

oracle 11g 从PSU 2018Oct(含)及之后的补丁不支持MD5. 要使用JDBC SSL要使用TSL1.2.
有两种方法,一种使用wallet, 一种使用JKS. 本文档使用wallets.

1. 为什么用TSL 1.2

https://blogs.oracle.com/developers/post/ssl-connection-to-oracle-db-using-jdbc-tlsv12-jks-or-oracle-wallets-122-and-lower#Wallets

提到:

JDK 7 and JDK 8 releases support TLSv1.2 protocol. The other protocols
such as TLSv1.1, TLSv1, SSLv3, and SSLv2 have security vulnerabilities
and the recommendation is to use the latest standard version TLSv1.2
and use more secure SSL cipher suites. Follow these pre-requisites
below to use TLSv1.2.

TLS 1.2是比较稳定的版本。建议使用它。

2. 使用TSL 1.2 ,需要什么环境

1) ojdbc8.jar

上文提到, 需要ojdbc8.jar, (是jdbc 12.2.0.1 的ojdbc8.jar).
注意,这里的12.2.0.1,不是数据库的版本。 而是JDBC Drivers的版本号。
更多版本参看:
https://www.oracle.com/database/technologies/appdev/jdbc-drivers-archive.html

实际从19c的$ORACLE_HOME/jdbc下得到ojdbc8.jar. 看其readme, 是12.2.0.1.0, 满足要求。:

Oracle JDBC Drivers release 12.2.0.1.0 production Readme.txt

如果从Oracle数据库12cR2的$ORACLE_HOME/jdbc下,看其readme, jdbc 版本是12.1.0.1.0 ,不满足要求。

Oracle JDBC Drivers release 12.1.0.1.0 production Readme.txt

另外几个jar获取方法,$ORACLE_HOME/jlib目录下:

cd $ORACLE_HOME/jlib
[oracle@RHEL8 jlib]$ cp oraclepki.jar /tmp
[oracle@RHEL8 jlib]$ cp osdt_cert.jar  /tmp
[oracle@RHEL8 jlib]$ cp osdt_core.jar  /tmp
cd /home/oracle/jdbc_tsl
cp /tmp/*.jar .

2) java环境。

需要JDK9 or JDK8u162或者以上
实际使用版本:1.8.0_391.

[oracle@RHEL8 trace]$ which java
/usr/local/jdk/bin/java
[oracle@RHEL8 trace]$ java -version
java version "1.8.0_391"
Java(TM) SE Runtime Environment (build 1.8.0_391-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.391-b13, mixed mode)

3. 如何确认jdbc版本和Oracle数据库的支持情况?

  • 文档: How To Configure Oracle JDBC Thin Driver To Connect To Database
    Using TLS v1.2 (Doc ID 2436911.1)
  • 文档 Starting With Oracle JDBC Drivers - Installation,
    Certification, and More! (Doc ID 401934.1)

从oracle客户端和数据库之间兼容表:
Client / Server Interoperability Support Matrix for Different Oracle Versions (Doc ID 207303.1)
可以看到:
Client
Version Server Version
23ai 21c 19c 18c 12.2.0 12.1.0 11.2.0
23ai#11 Yes Yes Yes No No No No
21c Yes Yes Yes Was Was Yes#12 No
19c Yes Yes Yes Was Was Yes#12 Yes#9
18c No Was Was Was Was Was Was#9
12.2.0 No Was Was Was Was Was Was#9
12.1.0 No Yes#12 Yes#12 Was Was Yes#12 Yes#12
11.2.0 No No Yes#9 Was#9 Was#9 Yes#12 Yes#9

数据库 11.2.0 ,客户端可以是 11.2.0, 直到 19c.

4. 其他参考文档

1)TLS Connection String For JDBC Thin Driver Without A Wallet (Doc ID 2970468.1)
把wallet的内容转化为jks

5. 步骤

先在数据库服务器上测试。

1) 生成数据库服务器的wallet

[oracle@RHEL8 scripts]$ cat ssl_sha256_onlyserver.sh
if [ -d /home/oracle/wallets ]; thenmv /home/oracle/wallets /home/oracle/wallets-`date +%y%m%d-%H%M%S`
fi
mkdir -p /home/oracle/wallets
cd /home/oracle/wallets #进入当前目录orapki wallet create -wallet ./server_wallet -auto_login -pwd Welcome1_
orapki wallet add -wallet ./server_wallet -sign_alg sha256 -dn "CN=server" -keysize 1024 -self_signed -validity 365 -pwd Welcome1_
orapki wallet display -wallet ./server_wallet
orapki wallet export -wallet ./server_wallet -dn "CN=server" -cert ./server_wallet/cert.txt
# check the alg
openssl x509 -noout -text -in ./server_wallet/cert.txt

注意, 生成wallet时,java.seciruty不能加下面的
security.provider.7=oracle.security.pki.OraclePKIProvider
否则执行失败。要先注释掉再生成wallet. 然后再加上。

2) Add the required dependant jars for using Oracle Wallets

cd $ORACLE_HOME/jlib
[oracle@RHEL8 jlib]$ cp oraclepki.jar /home/oracle/jdbc_tsl
[oracle@RHEL8 jlib]$ cp osdt_cert.jar  /home/oracle/jdbc_tsl
[oracle@RHEL8 jlib]$ cp osdt_core.jar  home/oracle/jdbc_tsl

3) Enable Oracle PKI provider

$ORACLE_HOME/jdk/jre/lib/security/java.security
security.provider.1=sun.security.provider.Sun
security.provider.2=sun.security.rsa.SunRsaSign
security.provider.3=com.sun.net.ssl.internal.ssl.Provider
security.provider.4=com.sun.crypto.provider.SunJCE
security.provider.5=sun.security.jgss.SunProvider
security.provider.6=com.sun.security.sasl.Provider
最后一行加上
security.provider.7=oracle.security.pki.OraclePKIProvider

4) 配置侦听

添加tpcs的端口

SSL_CLIENT_AUTHENTICATION = FALSE
WALLET_LOCATION =(SOURCE =(METHOD = FILE)(METHOD_DATA =(DIRECTORY = /home/oracle/wallets/server_wallet)))LISTENER =(DESCRIPTION_LIST =(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = RHEL8.localdomain)(PORT = 1521)))(DESCRIPTION =(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)))(DESCRIPTION =(ADDRESS = (PROTOCOL = TCPS)(HOST = 192.168.56.89)(PORT = 2484))))ADR_BASE_LISTENER = /u01/app/oracle修改sqlnet.oraNAMES.DIRECTORY_PATH= (TNSNAMES, EZCONNECT)ADR_BASE = /u01/app/oracleSSL_CLIENT_AUTHENTICATION = FALSE
WALLET_LOCATION =(SOURCE =(METHOD = FILE)(METHOD_DATA =(DIRECTORY = /home/oracle/wallets/server_wallet)))SQLNET.AUTHENTICATION_SERVICES= (BEQ,TCPS, NTS)

5) 重启侦听

lsnrctl stop
lsnrctl start

6) 修改测试java程序

下载测试程序,

https://github.com/oracle-samples/oracle-db-examples/blob/main/java/jdbc/ConnectionSamples/DataSourceSample.java

修改连接符, 用户名密码,加入security

  • 参考:
    https://blogs.oracle.com/developers/post/ssl-connection-to-oracle-db-using-jdbc-tlsv12-jks-or-oracle-wallets-122-and-lower#Wallets
//newline是新加的行。 连接符根据实际情况修改。import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;import oracle.jdbc.pool.OracleDataSource;
import oracle.jdbc.OracleConnection;
import java.sql.DatabaseMetaData;//for tsl 1.2
import java.security.Security;  //newline
import oracle.security.pki.OraclePKIProvider;  //newlinepublic class DataSourceSample {// The recommended format of a connection URL is the long format with the// connection descriptor.
final static String DB_URL = "jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS=(PROTOCOL=TCPS)(PORT=2484)(HOST=192.168.56.89))"+ "(CONNECT_DATA=(SERVICE_NAME=orcl))"+ "(SECURITY=(SSL_SERVER_CERT_DN=\"CN = server\")))";// For ATP and ADW - use the TNS Alias name along with the TNS_ADMIN when using 18.3 JDBC driver// final static String DB_URL="jdbc:oracle:thin:@wallet_dbname?TNS_ADMIN=/Users/test/wallet_dbname";// In case of windows, use the following URL// final static String DB_URL="jdbc:oracle:thin:@wallet_dbname?TNS_ADMIN=C:/Users/test/wallet_dbname";final static String DB_USER = "system";final static String DB_PASSWORD = "oracle";/** The method gets a database connection using* oracle.jdbc.pool.OracleDataSource. It also sets some connection* level properties, such as,* OracleConnection.CONNECTION_PROPERTY_DEFAULT_ROW_PREFETCH,* OracleConnection.CONNECTION_PROPERTY_THIN_NET_CHECKSUM_TYPES, etc.,* There are many other connection related properties. Refer to* the OracleConnection interface to find more.*/public static void main(String args[]) throws SQLException {
//for tsl1.2Security.addProvider(new OraclePKIProvider());//newline

7) 准备测试数据employees表

为systme用户建表employees,测试使用

sqlplus system/oracle
create table employees(first_name varchar2(10), last_name varchar2(10));
insert into employees values('a','a')
commit;

8) 测试脚本run.sh

[oracle@RHEL8 jdbc_tsl_wallets]$ cat run.shjavac -classpath ./ojdbc8.jar:./oraclepki.jar:./osdt_cert.jar:./osdt_core.jar:. DataSourceSample.javajava -classpath ./ojdbc8.jar:./oraclepki.jar:./osdt_cert.jar:./osdt_core.jar:. \
-Doracle.net.wallet_location="(SOURCE=(METHOD=file)(METHOD_DATA=(DIRECTORY=/home/oracle/wallets/server_wallet)))" \
-Doracle.net.ssl_server_dn_match=true DataSourceSample#-Doracle.net.tns_admin=./lib

9) 测试

[oracle@RHEL8 jdbc_tsl]$ ./run.sh
Driver Name: Oracle JDBC driver
Driver Version: 19.9.0.0.0
Default Row Prefetch Value is: 20
Database Username is: SYSTEMFIRST_NAME  LAST_NAME
---------------------
a a

6. 在客户端测试

1)测试目录jdbc_tls和wallets目录复制到客户端

把/home/oracle/jdbc_tls压缩复制到客户端并解压到相同的/home/oracle/jdb_tls目录。
复制wallets目录并解压到客户端的/home/oracle/wallet目录下.
必须要复制wallets.

2) 客户端安装jdk 1.8,

#cd /usr/local; tar zxvf jdk-8u391-linux-x64.tar.gz
#ln -s /usr/local/jdk1.8.0_391 jdk

并设置oracle的PATH

export PATH=/usr/local/jdk/bin:$ORACLE_HOME/bin:$PATH

java -version 确认版本是1.8

3)客户端测试

[oracle@hol jdbc_tsl]$ ./run.sh
Driver Name: Oracle JDBC driver
Driver Version: 19.9.0.0.0
Default Row Prefetch Value is: 20
Database Username is: SYSTEMFIRST_NAME  LAST_NAME
---------------------
a a

7. 其他错误分析参考文档

  • https://www.oracle.com/database/technologies/application-development/jdbc-eecloud-troubleshooting-tips.html
http://www.xdnf.cn/news/543367.html

相关文章:

  • 企业级网络安全护盾:剖析高防IP原理与防护策略
  • 编程学习论坛测试报告
  • 隐形安全感
  • Linux Bash 中 $? 的详细用法
  • 【算法】定长滑动窗口5.20
  • 畅游Diffusion数字人(30):情绪化数字人视频生成
  • MVDR源码(可直接运行)
  • HarmonyOS NEXT~鸿蒙系统与mPaaS三方框架集成指南
  • 单端传输通道也会有奇偶模现象喔
  • PIL库的图像增强函数
  • 从ISO17025合规到信创适配 解密质检lims系统实验室的 AI 质检全链路实践
  • 【C++】C++的拷贝构造函数介绍使用
  • 【RK3588嵌入式图形编程】-Cairo-形状与填充
  • C++从入门到实战(十六)String(中)String的常用接口(构造接口,析构接口,迭代器,遍历修改,容量管理与数据访问)
  • 零基础设计模式——创建型模式 - 单例模式
  • .NET 10 - 尝试一下Minimal Api的Validation新特性
  • 开源一个记账软件,支持docker一键部署
  • APPtrace 智能参数系统:重构 App 用户增长与运营逻辑
  • C++中String类
  • 《经济日报》深度聚焦|珈和科技携手万果博览荟共筑智慧农业新示范高地 全链赋能蒲江茶果产业数字化转型升级
  • 榕壹云上门家政系统:基于Spring Boot+MySQL+UniApp的全能解决方案
  • 深度剖析ZooKeeper
  • 基于大模型与人工智能体的机械臂对话式交互系统RobotAgent
  • 阿里云CDN刷新预热--刷新URL
  • 【AI 大模型】盘古大模型简介 ( 创建空间 | 体验模型 | 部署模型 )
  • 【华为OD-B卷-打印文件 100分(python、java、c++、js、c)】
  • 面试算法刷题3(核心+acm)
  • LVS原理详解及LVS负载均衡工作模式
  • Java的线程池相关的几个问题
  • Python 训练营打卡 Day 20-奇异值SVD分解