国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

oracle中通過DBMS_CRYPT!O包對表敏感字段進(jìn)行加密

2019-11-02 15:33:28
字體:
供稿:網(wǎng)友

 下面我們來看看oracle中通過DBMS_CRYPTO包對表敏感字段進(jìn)行加密方法,有需要了解的朋友可一起來看看吧.

 


在安全越來越重視的近體,我們不少時候需要對數(shù)據(jù)庫中的某個表的敏感列數(shù)據(jù)(銀行卡,身份證號碼,金額等)進(jìn)行加密,方式數(shù)據(jù)泄密,在11.2.0.4中可以通過dbms_crypto包方式實現(xiàn),增加oracle的加密效率,本文提供處理思路,其他可以根據(jù)需求盡情發(fā)揮
數(shù)據(jù)庫版本
SQL> select * from v$version;
 
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE    11.2.0.4.0      Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
[/shell]
<strong>創(chuàng)建加密函數(shù)</strong>
1
SQL> create or replace function f_Encrypt_number(number_in in varchar2) return raw is
  2  number_in_raw RAW(128):=UTL_I18N.STRING_TO_RAW(number_in,'AL32UTF8');
  3  key_number number(32):=32432432343243279898;
  4  key_raw RAW(128):=UTL_RAW.cast_from_number(key_number);
  5  encrypted_raw RAW(128);
  6  begin
  7  encrypted_raw:=dbms_crypto.Encrypt(src=>number_in_raw,typ=>DBMS_CRYPTO.DES_CBC_PKCS5,key=>key_raw);
  8  return encrypted_raw;
  9  end;
 10  /
 
Function created.
測試加密函數(shù)
SQL> select f_Encrypt_number('wwww.111cn.net') from dual;
 
F_ENCRYPT_NUMBER('WWWW.111cn.net')
--------------------------------------------------------------------------------
003CB89CB77F6644C93AE2CF7810B0E3E3B10B8C60B54058
創(chuàng)建解密函數(shù)
SQL> create or replace function f_decrypt_number (encrypted_raw IN RAW)
  2  return varchar2 is
  3  decrypted_raw raw(48);
  4  key_number number(32):=32432432343243279898;
  5  key_raw RAW(128):=UTL_RAW.cast_from_number(key_number);
  6  begin
  7  decrypted_raw := DBMS_CRYPTO.DECRYPT
  8  (
  9  src => encrypted_raw,
 10  typ => DBMS_CRYPTO.DES_CBC_PKCS5,
 11  key => key_raw
 12  );
 13  return UTL_I18N.RAW_TO_CHAR (decrypted_raw, 'AL32UTF8');
 14  END;
 15  /
 
Function created.
測試解密函數(shù)
SQL> select f_decrypt_number('003CB89CB77F6644C93AE2CF7810B0E3E3B10B8C60B54058') from dual;
 
F_DECRYPT_NUMBER('003CB89CB77F6644C93AE2CF7810B0E3E3B10B8C60B54058')
--------------------------------------------------------------------------------
wwww.111cn.net
創(chuàng)建表綜合測試
SQL> create table xifenfei_crypto
  2  (id number, name varchar2(20),en_name raw(128)) ;
 
Table created.
 
SQL> insert into xifenfei_crypto (id,name) select object_id,object_name from dba_objects where rownum<10;

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 贡山| 金昌市| 丰原市| 郑州市| 万源市| 马龙县| 莒南县| 山东省| 碌曲县| 黔西县| 临漳县| 梅河口市| 武隆县| 永州市| 德钦县| 陆良县| 遂平县| 阿拉尔市| 海兴县| 南溪县| 吴堡县| 昌都县| 德格县| 连州市| 宝应县| 星子县| 竹北市| 广州市| 随州市| 东乡县| 渝北区| 崇明县| 巴青县| 资兴市| 湖口县| 建昌县| 平阴县| 罗源县| 定南县| 哈密市| 遂平县|