Oracle自定义加密解密函数

--加密函数
CREATE OR REPLACE function FUN_ENCRYPT(p_text varchar2) return varchar2 is
    v_text varchar2(4000);
    v_key varchar2(4000);
    v_enc varchar2(4000);
    raw_input RAW(20000) ;
    key_input RAW(1000) ;
    decrypted_raw RAW(20000);
    v_ErrorText varchar2(500);
begin
    if(p_text is null or p_text = '' )
        then return '';
    end if;
	-- 注意修改
    v_key := 'jzhhfzq123456789';

    dbms_output.put_line(p_text);
    v_text := rpad( p_text, (trunc(lengthb(p_text)/8)+1)*8, chr(0));
    dbms_output.put_line(v_text);
    raw_input := UTL_I18N.STRING_TO_RAW(v_text,'ZHS16GBK');
    key_input := UTL_I18N.STRING_TO_RAW(v_key,'ZHS16GBK');
    dbms_obfuscation_toolkit.DESEncrypt(input => raw_input,key => key_input,encrypted_data =>decrypted_raw);
    v_enc := rawtohex(decrypted_raw);
    dbms_output.put_line(v_enc);
    return v_enc;
    exception
    when others then
    --自定义异常,并捕获输出异常信息
    v_ErrorText := 'dserror:'||SUBSTR(SQLERRM, 1, 200);
    return v_ErrorText;
end;
/

--解密函数
CREATE OR REPLACE function FUN_DECRYPT(p_text varchar2) return varchar2 is
    v_text varchar2(4000);
    v_key varchar2(4000);
    p_text_raw RAW(20000);
    p_key_raw RAW(20000);
    v_text_raw RAW(20000);
    v_ErrorText varchar2(500);
begin
    if(p_text is null or p_text = '' )
    then return '';
    end if;
    -- 注意修改
    v_key := 'jzhhfzq123456789';

    p_text_raw := HEXTORAW(p_text);
    p_key_raw := UTL_I18N.STRING_TO_RAW(v_key, 'ZHS16GBK');
    dbms_obfuscation_toolkit.DESDECRYPT(input => p_text_raw, key =>p_key_raw, decrypted_data=> v_text_raw);
    v_text := UTL_I18N.RAW_TO_CHAR(v_text_raw, 'ZHS16GBK');
    dbms_output.put_line(v_text);
    return rtrim(v_text,chr(0));
    exception
    when others then
    --自定义异常,并捕获输出异常信息
    v_ErrorText := 'dserror:'||SUBSTR(SQLERRM, 1, 200);
    return v_ErrorText;
end;
-- 测试加密
select FUN_ENCRYPT('卡卡罗特') from dual;

-- 测试解密
select FUN_DECRYPT('9644DF3D1692E58EB8B66E1A0B779AD9') from dual;
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值