📄 enc_dec_master.sql
字号:
REM
REM Define a variable to hold the encrypted value
VARIABLE enc_val varchar2(2000);
DECLARE
l_key VARCHAR2 (2000) := '1234567890123456';
l_master_key VARCHAR2 (2000) := '&master_key';
l_in_val VARCHAR2 (2000) := 'Confidential Data';
l_mod NUMBER
:= DBMS_CRYPTO.encrypt_aes128
+ DBMS_CRYPTO.chain_cbc
+ DBMS_CRYPTO.pad_pkcs5;
l_enc RAW (2000);
l_enc_key RAW (2000);
BEGIN
l_enc_key :=
UTL_RAW.bit_xor (utl_i18n.string_to_raw (l_key, 'AL32UTF8'),
utl_i18n.string_to_raw (l_master_key, 'AL32UTF8')
);
l_enc :=
DBMS_CRYPTO.encrypt (utl_i18n.string_to_raw (l_in_val, 'AL32UTF8'),
l_mod,
l_enc_key
);
DBMS_OUTPUT.put_line ('Encrypted=' || l_enc);
:enc_val := RAWTOHEX (l_enc);
END;
/
DECLARE
l_key VARCHAR2 (2000) := '1234567890123456';
l_master_key VARCHAR2 (2000) := '&master_key';
l_in_val RAW (2000) := HEXTORAW (:enc_val);
l_mod NUMBER
:= DBMS_CRYPTO.encrypt_aes128
+ DBMS_CRYPTO.chain_cbc
+ DBMS_CRYPTO.pad_pkcs5;
l_dec RAW (2000);
l_enc_key RAW (2000);
BEGIN
l_enc_key :=
UTL_RAW.bit_xor (utl_i18n.string_to_raw (l_key, 'AL32UTF8'),
utl_i18n.string_to_raw (l_master_key, 'AL32UTF8')
);
l_dec := DBMS_CRYPTO.decrypt (l_in_val, l_mod, l_enc_key);
DBMS_OUTPUT.put_line ('Decrypted=' || utl_i18n.raw_to_char (l_dec));
END;
/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -