分享
 
 
 

Oracle 11gR1中的表空间加密

王朝other·作者佚名  2008-05-21
窄屏简体版  字體: |||超大  

阅读提示:Oracle 10gR2中引入了透明数据加密功能后,大大简化了加密数据文件中的数据,预防来自操作系统的访问,表空间加密扩展了这种技术,允许对表空间中的内容条目进行加密,而不是基于一列一列地配置加密。

创建wallet

设置表空间加密的环境与透明数据加密的环境一致,在尝试创建一个加密表空间之前,先要创建一个wallet来保留加密密钥,按照下面的顺序搜索wallet:

1、sqlnet.ora文件中参数ENCRYPTION_WALLET_LOCATION指定的位置

2、sqlnet.ora文件中参数WALLET_LOCATION指定的位置

3、wallet默认位置($ORACLE_BASE/admin/$ORACLE_SID/wallet)

尽管加密表空间可以共享默认的数据库wallet,但Oracle建议你为透明数据加密功能单独使用一个wallet,只需要在 sqlnet.ora文件中为参数ENCRYPTION_WALLET_LOCATION指定一个值即可,我们在sqlnet.ora文件中添加了下面的 行,并确保指定的目录已经被创建好了。

ENCRYPTION_WALLET_LOCATION=

(SOURCE=(METHOD=FILE)(METHOD_DATA=

(DIRECTORY=/u01/app/oracle/admin/DB11G/encryption_wallet/)))

这个参数也可用于标识硬件安全模型(HSM)作为wallet位置。

下面的命令创建和打开wallet。

CONN sys/password@db11g AS SYSDBA

ALTER SYSTEM SET ENCRYPTION KEY AUTHENTICATED BY "myPassword";

wallet在实例重启后必须重新打开才能防止对加密数据的访问。

ALTER SYSTEM SET WALLET OPEN IDENTIFIED BY "myPassword";

ALTER SYSTEM SET WALLET CLOSE;

创建表空间

加密表空间是通过带有USING子句指定加密算法的ENCRYPTION子句创建的,如果没有USING子句,默认的加密算法是AES128,另 外,必须指定default storage(encrypt)子句,表空间加密不允许在TDE(透明数据加密)可用的NO SALT选项,下面的语句创建了一个加密表空间,用USING子句明确地指出了加密算法使用AES256。

CREATE TABLESPACE encrypted_ts

DATAFILE '/u01/app/oracle/oradata/DB11G/encrypted_ts01.dbf' SIZE 128K

AUTOEXTEND ON NEXT 64K

ENCRYPTION USING 'AES256'

DEFAULT STORAGE(ENCRYPT);

ALTER USER test QUOTA UNLIMITED ON encrypted_ts;

视图DBA_TABLESPACES和USER_TABLESPACES中的ENCRYPTED列指出了表空间是否加密。

SELECT tablespace_name, encrypted FROM dba_tablespaces;

TABLESPACE_NAME ENC

------------------------------ ---

SYSTEM NO

SYSAUX NO

UNDOTBS1 NO

TEMP NO

USERS NO

ENCRYPTED_TS YES

6 rows selected.

SQL>

普通表空间是不能转换到加密表空间的,相反,数据必须被手工使用导出/导入进行转移,“alter table ... move ...”或“create table ... as select * from ...”

测试加密

我们可以创建一些对象测试加密,下面的代码在加密表空间中创建了一个表和一个索引,并在表中插入了一行数据。

CONN test/test@db11g

CREATE TABLE ets_test (

id NUMBER(10),

data VARCHAR2(50)

)

TABLESPACE encrypted_ts;

CREATE INDEX ets_test_idx ON ets_test(data) TABLESPACE encrypted_ts;

INSERT INTO ets_test (id, data) VALUES (1, 'This is a secret!');

COMMIT;

清空缓冲区确保数据写入到数据文件中。

CONN sys/password@db11g AS SYSDBA

ALTER SYSTEM FLUSH BUFFER_CACHE;

当使用十六进制编辑器(如UltraEdit)打开这个文件时只能看到不可打印的字符,在加密表空间的表或索引中的数据是不可见的,成为了机密信息!

当你测试完加密表空间,一定要清除表空间和对应的数据文件。

DROP TABLESPACE encrypted_ts INCLUDING CONTENTS AND DATAFILES;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有