2021-02-04

本文详细介绍了在C/S架构下,为满足等保要求,如何配置Oracle数据库的加密和一致性校验。通过设置SQLNET.ENCRYPTION_SERVER、SQLNET.ENCRYPTION_TYPES_SERVER、SQLNET.CRYPTO_CHECKSUM_SERVER等参数,确保服务器和客户端的数据传输安全。测试环境为11.2.0.4的Oracle服务器和Windows 10客户端,采用RC4_256加密算法,并使用Wireshark验证了加密效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C/S架构数据加密设置

由于用户等保要求,需要对数据传输进行加密。参考了相关资料,经过几个小时的测试对比终于确定可以达到预期效果。系统采用数据库直连的方式,可以使用Oracle自带的加密方式。
server端和client端的加密级别、一致性校验分四种级别
SQLNET.ENCRYPTION_SERVER|CLIENT
SQLNET.CRYPTO_CHECKSUM_SERVER|CLIENT

参数解释:
SQLNET.CRYPTO_CHECKSUM_CLIENT。默认设置为ACCEPTED。

参数说明
ACCEPTED - 客户端不请求使用校验和,但是如果服务器请求校验和,则请求。兼容的服务器参数为REJECTED,REQUESTED和REQUIRED。
REJECTED - 客户端不支持使用校验和。兼容的服务器参数为REJECTED,ACCEPTED和REQUESTED。
REQUESTED - 客户端喜欢使用校验和,但是如果服务器拒绝它们的使用,则不强制该问题。兼容的服务器参数是ACCEPTED,REQUESTED和REQUIRED。
REQUIRED - 客户端要求使用校验和,否则不连接。兼容的服务器参数是ACCEPTED,REQUESTED和REQUIRED。

SQLNET.CRYPTO_CHECKSUM_SERVER。默认设置为ACCEPTED。

参数
ACCEPTED - 服务器不请求使用校验和,但如果客户端请求它们,请继续。兼容的服务器参数有:REJECTED,REQUESTED和REQUIRED。
REJECTED - 服务器根本不支持使用校验和。兼容的客户端参数为REJECTED,ACCEPTED和REQUESTED。
REQUESTED - 服务器更喜欢使用校验和,但是如果客户端拒绝它们的使用,则不强制该问题。兼容的客户端参数是ACCEPTED,REQUESTED和REQUIRED。
REQUIRED - 服务器要求使用校验和,否则不连接。兼容的客户端参数是ACCEPTED,REQUESTED和REQUIRED。

加密参数解释参考一致性校验。

因为系统通过oracle客户端软件连接数据库所以只针对这种情况做测试
测试环境:
服务器
11.2.0.4 winodows2008R2
客户端端
win10
安装抓包工具Wireshark,安装抓包工具的使用可以百度
客户端和服务器端设置如下:
服务器端:
SQLNET.ENCRYPTION_SERVER = REQUIRED ----加密级别
SQLNET.ENCRYPTION_TYPES_SERVER = RC4_256 ----加密算法
SQLNET.CRYPTO_CHECKSUM_SERVER = REQUIRED — 一致性能校验
客户端
SQLNET.ENCRYPTION_CLIENT = REQUIRED
SQLNET.ENCRYPTION_TYPES_CLIENT = RC4_256
SQLNET.CRYPTO_CHECKSUM_CLIENT = REQUIRED

打开抓包工具后运行系统,可以在转包工具种开到客户端请求和服务端响应的数据都进行了加密

链接: 转自 http://blog.itpub.net/24052272/viewspace-2129175/.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值