午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    oracle中通過(guò)DBMS_CRYPTO包對(duì)表敏感字段進(jìn)行加密
    來(lái)源:易賢網(wǎng) 閱讀:1348 次 日期:2015-03-20 11:26:20
    溫馨提示:易賢網(wǎng)小編為您整理了“oracle中通過(guò)DBMS_CRYPTO包對(duì)表敏感字段進(jìn)行加密”,方便廣大網(wǎng)友查閱!

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

    在安全越來(lái)越重視的近體,我們不少時(shí)候需要對(duì)數(shù)據(jù)庫(kù)中的某個(gè)表的敏感列數(shù)據(jù)(銀行卡,身份證號(hào)碼,金額等)進(jìn)行加密,方式數(shù)據(jù)泄密,在11.2.0.4中可以通過(guò)dbms_crypto包方式實(shí)現(xiàn),增加oracle的加密效率,本文提供處理思路,其他可以根據(jù)需求盡情發(fā)揮

    數(shù)據(jù)庫(kù)版本

    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.

    測(cè)試加密函數(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.

    測(cè)試解密函數(shù)

    SQL> select f_decrypt_number('003CB89CB77F6644C93AE2CF7810B0E3E3B10B8C60B54058') from dual;

    F_DECRYPT_NUMBER('003CB89CB77F6644C93AE2CF7810B0E3E3B10B8C60B54058')

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

    wwww.111cn.net

    創(chuàng)建表綜合測(cè)試

    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;

    9 rows created.

    SQL> commit;

    Commit complete.

    SQL> select * from xifenfei_crypto;

    ID NAME EN_NAME

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

    20 ICOL$

    46 I_USER1

    28 CON$

    15 UNDO$

    29 C_COBJ#

    3 I_OBJ#

    25 PROXY_ROLE_DATA$

    41 I_IND1

    54 I_CDEF2

    9 rows selected.

    SQL> update xifenfei_crypto set en_name=f_Encrypt_number(name);

    9 rows updated.

    SQL> commit;

    Commit complete.

    SQL> select * from xifenfei_crypto;

    ID NAME EN_NAME

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

    20 ICOL$ FE17B031331839A9

    46 I_USER1 FEF96765B1E2C53C

    28 CON$ 0283FCE900ACED5C

    15 UNDO$ 20DD92762F199436

    29 C_COBJ# A0CB43E2EA6BA889

    3 I_OBJ# F2DE1B9C8A39AA3D

    25 PROXY_ROLE_DATA$ 62B99C02EBD4B250311E4490207FEF18CBD8CD8FBA1BFD81

    41 I_IND1 3F4C3C186F8E2F52

    54 I_CDEF2 CA23D202802BD3AC

    9 rows selected.

    SQL> select id,name,f_decrypt_number(EN_NAME) de_name,en_name from xifenfei_crypto;

    ID NAME DE_NAME EN_NAME

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

    20 ICOL$ ICOL$ FE17B031331839A9

    46 I_USER1 I_USER1 FEF96765B1E2C53C

    28 CON$ CON$ 0283FCE900ACED5C

    15 UNDO$ UNDO$ 20DD92762F199436

    29 C_COBJ# C_COBJ# A0CB43E2EA6BA889

    3 I_OBJ# I_OBJ# F2DE1B9C8A39AA3D

    25 PROXY_ROLE_DATA$ PROXY_ROLE_DATA$ 62B99C02EBD4B250311E4490207FEF18CBD8CD8FBA1BFD81

    41 I_IND1 I_IND1 3F4C3C186F8E2F52

    54 I_CDEF2 I_CDEF2 CA23D202802BD3AC

    9 rows selected.

    更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

    更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國(guó)考·省考課程試聽(tīng)報(bào)名

    • 報(bào)班類(lèi)型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專(zhuān)用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)