最近几年发生了很多脱库的事件,有些时候安全不到位脱库再所避免,但是可以通过某些技术对数据库进行加密,让即使通过脱库得到的库也没法查看。

在技术层面的实现可以分为应用和数据库层。

(1)通过在程序端对某些敏感的信息就进行加密进行存放

(2)通过在数据库端对库进行加密存放

对于数据库端的技术,Oracle在10g的时候就推出了TDE(Transparent Data Encryption,透明数据加密)特性。这个特性简单来说就是对存放的数据再加了一道壳,脱库拿到的数据库其实是加了这个壳的,拿到也没啥用,除非把这个壳再进行破解。这个壳Oracle给出了这几种加密算法:3DES168、AES128、AES192、AES256。

使用这个技术大概分为如下几步:

(1)创建存放壳秘钥的文件夹

(2)修改 sqlnet.ora配置,在sqlnet.ora文件中指定一个wallet路径

(3)创建主秘钥

(4)开启wallet

(5)创建表空间

(6)如果粒度要更细一些的话,可以对表以及表的字段进行Encryption

使用步骤:

1.创建目录
mkdir -p $ORACLE_BASE/admin/orcl/wallet

2.在sqlnet.ora中添加如下
ENCRYPTION_WALLET_LOCATION = (SOURCE =
(METHOD = FILE)
(METHOD_DATA =
(DIRECTORY =/u01/app/oracle/admin/orcl/wallet)))

3.创建主秘钥
ALTER SYSTEM SET ENCRYPTION KEY IDENTIFIED BY password;

4.数据库如果重启之后,秘钥是会被关闭的,用如下命令可以打开秘钥
ALTER SYSTEM SET [ENCRYPTION] WALLET OPEN IDENTIFIED BY password

5.创建表空间
CREATE TABLESPACE securespace
DATAFILE '/u01/app/oracle/oradata/orcl/secure01.dbf' SIZE 100M
ENCRYPTION USING 'AES256'
DEFAULT STORAGE(ENCRYPT);

6.剩下的就是使用
如果需要使用这个特性就可以把表创建在这个表空间上了。对于已经存在的表,可以使用alter table move tablespace的方式进行move(要记得索引也需要rebuild)。

7.需要注意的:

wallet密码跟我们这里要修改的master key不是一个东西,wallet密码仅仅是登陆owm或进行wallet时需要输入的密码,而master key是存放在wallet中,用于加密解密数据库的加密列或加密表空间。

另外还有一个表密钥,如果一个表有多个列需要进行加密,那么在该表上也只会生成一个表级密钥,当前段用户从该表中取回数据时,会首先取出表密钥然后再取出存在wallet中的master key进行对表密钥的解密,最后用解密后的表密钥去解密加密的列或表空间数据,最终返回明文数据给用户。


测试:

在这儿做一个效果测试,测试的步骤为创建2个表空间(一个为加密的一个为不加密的),创建2个用户默认的表空间对应这2个表空间,然后分别登陆2个用户,创建同样的表,插入数据,然后最后再操作系统上来看,看能否通过操作系统的命令看到插入的数据。

1.创建加密的表空间sec_yes

SQL> create tablespace sec_yes datafile '/u01/app/oracle/oradata/orcl/secyes01.dbf' size 20M
2 ENCRYPTION USING 'AES256'
3 DEFAULT STORAGE(ENCRYPT);

Tablespace created.

2.创建不加密的表空间sec_no

SQL> create tablespace sec_no datafile '/u01/app/oracle/oradata/orcl/secno01.dbf' size 20M;

Tablespace created.

3.创建用户test1默认表空间为sec_yes

SQL> create user test1 identified by test1 default tablespace sec_yes;

User created.

4.创建用户test2认表空间为sec_no

SQL> create user test2 identified by test2 default tablespace sec_no;

User created.

SQL>

[oracle@test admin]$ sqlplus / as sysdba

SQL*Plus: Release 11.1.0.7.0 - Production on Tue Feb 16 17:12:14 2016

Copyright (c) 1982, 2008, Oracle. All rights reserved.

Connected to:
Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

5.登陆用户test1创建表并插入数据

SQL> conn test1/test1
Connected.

SQL> create table test1 (remark varchar2(20));

Table created.

SQL> insert into test1 values ('show me the money');

1 row created.

SQL> commit;

Commit complete.

6.登陆用户test2创建表并插入数据

SQL> conn test2/test2
Connected.
SQL> create table test2 (remark varchar2(20));

Table created.

SQL> insert into test2 values ('show me the money');

1 row created.

SQL> commit;

Commit complete.

7.将脏数据写入到磁盘

SQL> ALTER SYSTEM FLUSH BUFFER_CACHE;

System altered.

SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

8.进入到存放数据文件的地方,用strings命令看能否查看到数据
[oracle@test admin]$ cd /u01/app/oracle/oradata/
[oracle@test oradata]$ ls
orcl
[oracle@test oradata]$ cd orcl/
[oracle@test orcl]$ ls
control01.ctl control03.ctl redo01.log redo03.log secyes01.dbf system01.dbf undotbs01.dbf
control02.ctl example01.dbf redo02.log secno01.dbf sysaux01.dbf temp01.dbf users01.dbf
[oracle@test orcl]$ strings secyes01.dbf | grep "show"
[oracle@test orcl]$ strings secno01.dbf | grep "show"
show me the money
[oracle@test orcl]$

可以看到没有加密的表空间能看到存入的数据,而加密了的表空间则看不到。

Oracle“钱夹”的使用的更多相关文章

  1. Oracle中对列加密的方法

    Oracle中对列加密的方法 2011-12-22 17:21:13 分类: Linux Oracle支持多种列加密方式: 1,透明数据加密(TDE):create table encrypt_col ...

  2. oracle TDE

    转自:oracle TDE学习系列 (1) — wallet 使用管理 关于oracle wallet,通常称为oracle钱夹,说的通俗一点,oracle wallet是一个用 口令加密的PKCS# ...

  3. Oracle 数据库加密

    数据加密 动态数据(data in motion)和静态数据(data at rest),除了手动加密,其他的加密都需要oracle企业版的高级加密(额外收费——)  1 静态数据加密 Example ...

  4. Oracle RMAN 学习:演练进阶篇

    Oracle RMAN 学习:演练进阶篇 5 Rman备份演练进阶篇 5.1 是否选择增量备份 Backup命令生成的备份集中只备份了那些使用了的数据块,备份集实际大小已经较目标数据库的数据文件小了很 ...

  5. 透明数据加密 (TDE)常见问题解答

    透明数据加密 (TDE)常见问题解答问题任何人只要有权访问加密数据就能对其进行解密吗?TDE 会带来哪些开销?哪些加密算法可与 TDE 一同使用?可以使用第三方加密算法代替 TDE 提供的算法吗?可以 ...

  6. oracle技巧-持续更新

    1. 登录oracle数据库,执行select status from v$encryption_wallet,如果返回OPEN,表示钱夹已自动打开. 2.

  7. Oracle数据安全解决方案(1)——透明数据加密TDE

    Oracle数据安全解决方案(1)——透明数据加密TDE2009年09月23日 22:49:00 华仔爱技术 阅读数:7991原文地址: http://www.oracle.com/technolog ...

  8. ORACLE透明加密

    --官网文档:https://www.oracle.com/technetwork/cn/tutorials/tde-096009-zhs.html#t概述Oracle 数据库 10g 第 2 版透明 ...

  9. oracle加密--wallet

    SQL> SELECT * FROM V$ENCRYPTION_WALLET; WRL_TYPE WRL_PARAMETER STATUS -------------------- ------ ...

随机推荐

  1. Swift-UIButton

    // let bt = UIButton(frame:CGRectMake(10,20,50,50)) let button = UIButton(frame:CGRectMake(10, 150, ...

  2. APEX初步

    APEX是SFDC中用于开发的语言.语法上类似JAVA等面向对象的语言,运行起来类似数据库中的存储过程.可以在SFDC事件中添加业务逻辑,操作相关数据和用在Visual Force页面中. 保存,编译 ...

  3. JSP多文件上传到服务器

    问题描述: 作为一个Java开发Web方向的程序员,很重要的一个功能,就是上传文件功能是一定要掌握的,今天整理了一下代码. 1.JSP显示界面代码和动态添加上传文件个数. <%@ page la ...

  4. 决策树及R语言实现

    决策树是什么 决策树是基于树结构来进行决策,这恰是人类在面临决策问题时一种很自然的处理机制.例如,我们要对"这是好瓜吗?"这样的问题进行决策时,通常会进行一系列的判断或" ...

  5. Intellij Idea/Webstorm/Phpstorm 版本控制忽略文件

    本地差异化配置,不需要提交,这时候需要在整个版本控制中忽略掉文件的提交. File -> Settings -> Version Control -> Ignored Files

  6. python网络编程学习笔记(三):socket网络服务器(转载)

    1.TCP连接的建立方法 客户端在建立一个TCP连接时一般需要两步,而服务器的这个过程需要四步,具体见下面的比较. 步骤 TCP客户端 TCP服务器 第一步 建立socket对象  建立socket对 ...

  7. 兼容好的JS图片上传预览代码

    转 : http://www.codefans.net/articles/1395.shtml 兼容好的JS图片上传预览代码 (谷歌,IE11) <html xmlns="http:/ ...

  8. jquery 自定义click事件执行多次

    用jquery绑定一个按钮click事件后,第一次点击后一切正常,第二次点击竟然执行两次,以后越来越多, 后来查看文档发现 jquery click 不是替换原有的function 而是接着添加,所以 ...

  9. CSS Sprites优缺点

    利用CSS Sprites能很好地减少网页的http请求,从而大大的提高页面的性能,这也是CSS Sprites最大的优点,也是其被广泛传播和应用的主要原因: CSS Sprites能减少图片的字节, ...

  10. windows7设置开机启动方式

    打开计算机(资源管理器)(快捷键win+e),输入 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Startup 将需要开机启动的软件的快捷 ...