数据安全:通过Oracle的基本函数实现简单加密脱敏函数

摘要:
概述这里我们主要介绍两个简单的加密和解密函数,这可能也是每个人都常用的。一个是内部翻译函数,另一个是使用md5算法创建的用户定义函数。示例截图:使用内部翻译功能。2.使用内部翻译功能来使用此功能。可以满足上述三个要求,并且可以根据其自身的设计来准备该函数的模糊字符内容,这不容易解密。

注我们获得更多精彩

640?wx_fmt=jpeg


作者 | 苏星开,云和恩墨南区交付技术顾问,曾服务过通信、能源生产、金融等行业客户,擅长 SQL 审核和优化,DataGuard 容灾等。



 概述


这里主要介绍两种操作简易的加密脱密函数,可能也是大家都比较常用。一个是内部 translate 函数,另外一个是利用 md5 算法创建的自定义函数。介绍这两个加密方法,主要还是在对一些业务数据做脱敏有这样的要求:

1、脱敏字段全部内容加密模糊化,部分加密模糊不行,

2、保持字段各条记录的原来数据关系,

3、加密后的数据长度与原来保持一样。


没有这些条件,加密脱敏方法还是比较多的,同时满足以上的要求,就不容易满足了。


比如以下的利用 MD5 创建自定义函数,满足了 1 和 2 的要求,却满足不了 3 的要求。

 使用 md5 算法创建函数


1. 使用 md5 算法创建函数(输出与原字段不等长度的十六进制字符串 )

create or replace function fn_md5(input_string VARCHAR2) return varchar2   
IS  
raw_input RAW(128) := UTL_RAW.CAST_TO_RAW(input_string);   
decrypted_raw RAW(2048);   
error_in_input_buffer_length EXCEPTION;   
BEGIN  
sys.dbms_obfuscation_toolkit.MD5(input => raw_input,checksum => decrypted_raw);   
return rawtohex(decrypted_raw);   
END;

/


这个自定义的加密函数虽然是达成了加密的目的,复杂度也相当高,原来相同的记录加密后的字符串也是一样的,只是加密后的字符串跟原来的长度不一致,不过也容易被解密。

 

示例截图:

640?wx_fmt=png

 

 使用内部 translate 函数


2. 使用内部 translate 函数(输出与原字段等长度的字符串)

使用这个函数以上三个要求都能满足,而且该函数模糊出来的字符内容可以按自己的设计拟定的,不容易被解密。


示例截图:

640?wx_fmt=png


对于 translate 函数,translate(col,x,y),x 的被取代内容的格式(字符型与数字型)表现不一样,加密后出来的字符串也有所不一样。

 

创建另外一个测试表:

640?wx_fmt=png


插入测试数据并查看:

640?wx_fmt=png


被取代的数据以数字型被取代:

640?wx_fmt=png

0 没有被替换成 ’a’,也没有被替代成任何字符。

 

被取代的数据以字符型被取代:

640?wx_fmt=png

‘0’被替换成’a’。

 

在各种加密脱敏方法中,不管使用哪一种方法,容易还是简单,只要适合脱敏的需求。上面两个只是简单的举例。


作者:苏星开

投稿:有投稿意向技术人请在公众号对话框留言。

转载:意向文章下方留言。

更多精彩请关注 “数据和云” 公众号


招聘专栏

Oracle 售前工程师(广州、深圳、上海、武汉、北京、石家庄)

Oracle 高级工程师(上海、深圳、北京、成都、昆明、贵州、西宁)

MySQL 技术经理(上海、南京、成都)

MySQL 工程师(上海、杭州)

超高待遇:丰厚的年终奖,五险一金,高额学习基金,团建旅游,法定节假日,福利假期等。

推荐他人成功入职有好礼(iPhone X)相送 。

投递简历至邮箱:hr@enmotech.com

资源下载

关注公众号:数据和云(OraNews)回复关键字获取

2018DTCC , 数据库大会PPT

2017DTC,2017 DTC 大会 PPT

DBALIFE ,“DBA 的一天”海报

DBA04 ,DBA 手记4 电子书

122ARCH ,Oracle 12.2体系结构图

2017OOW ,Oracle OpenWorld 资料

PRELECTION ,大讲堂讲师课程资料

近期文章

仅仅使用AWR做报告? 性能优化还未入门

实战课堂:一则CPU 100%的故障分析

杨廷琨:如何编写高效SQL(含PPT)

一份高达555页的技术PPT会是什么样子?

大象起舞:用PostgreSQL解海盗分金问题

ProxySQL!像C罗一样的强大

高手过招:用SQL解决环环相扣刑侦推理问题

640?wx_fmt=jpeg

免责声明:文章转载自《数据安全:通过Oracle的基本函数实现简单加密脱敏函数》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇首次启动速度慢的问题记录IIS性能优化socket.io 入门篇(二)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

oracle 11g 安装与卸载

安装 点击是,这是位数不一致,但可用。 桌面类――这种安装方式一般适用于台式机和笔记本。它包含一个最小数据库和最低的配置需求。 服务器类――这种安装方式适用于服务器,例如,它会向您提供数据中心和用于支持企业级的应用程序。如果您需要使用高级配置选项,请选择此安装类型。 在桌面类中,只有基本选择项。 在服务器类,可以选择标准安装(仅让您作有基本选择)或...

Oracle触发器详细 和 Oracle 创建序列号

由于这段时间要导入旧的数据库数据到新的数据库中,然而旧的数据库和新的数据库有些表的设计或字段不一样, 需要用到触发器,比如新的数据库a表有aid的主键字段(或自动递增),而旧的数据库a表没有aid的主键字段, 这时候要通过调用触发器,在copy数据时自动插入aid值同时要保证主键唯一性。 解决方案: 在旧数据库新建一个视图,通过视图导入到新的数据库中 --...

oracle最大连接数导致应用挂掉

配置keepalive+nginx高可用的时候,启动了应用,发现连接到后台的数据库报错: Caused by: java.sql.SQLRecoverableException: IO 错误: Socket read timed out at oracle.jdbc.driver.T4CConnection.logon(T4CConnection....

Oracle笔记

一、概念 1.表空间:段->分区->块 。表空间分类:系统、临时表、永久表、大小文件表 。段分类:数据段、临时段、索引段、回滚段。 2.该关心的11G新特性:=>符号指定函数特定参数、序列、正则表达式、触发器、continue可以再循环使用。 二、sql 基础(不熟部分) DDL: 1.索引 2.修改表:alter add(列) modi...

oracle10g安装,卸载

一、安装 1.因为oracle的特殊性,笔者选择通过虚拟机安装windows7旗舰版安装数据库,大家的系统假设是windows xp。windows 7,windows 8能够直接安装,windows 10对于该版本号的oracle存在不兼容,不推荐使用。 2.笔者使用的是oracle10g的压缩包。大家也能够使用镜像进行安装,打开oracle安装程序...

oracle中监听程序当前无法识别连接描述符中请求服务 的解决方法

原因如下: 你oracle安装成功后,一直未停止数据库(即数据库是启动的),客户端配置成功后,应该一直不会有什么问题。 而一旦你和我同事一样,有时把Oracle安装在虚拟机中,而且Oracle安装完毕后,没在进行任何监听的配置,则虚拟机再启动,则就会出现ORA-12514的问题。如下图       如下是解决思路: 根据出错信息判断出客户端未监听...