oracle的加解密函数
2016-02-26 16:35
549 查看
-- 加密函数 CREATE OR REPLACE FUNCTION FUN_ENCRYPTION( V_STR VARCHAR2 , V_KEY VARCHAR2 ) RETURN VARCHAR2 AS V_KEY_RAW RAW(24) ; V_STR_RAW RAW(2000) ; V_RETURN_STR VARCHAR2(2000) ; V_TYPE PLS_INTEGER ; BEGIN /************************************************* 加密函数 FUN_ENCRYPTION 入参: V_STR 输入明文字符串 V_KEY 输入密钥字符串,长度为24字节 返回值: V_RETURN_STR 返回密文字符串,约定返回为 16进制密文字符串 异常处理: 此函数不对任何异常做捕捉处理,请相应的程序模块对异常做捕捉处理。 加密方式: 密钥位数:AES192 DBMS_CRYPTO.ENCRYPT_AES192 连接方式:CBC DBMS_CRYPTO.CHAIN_CBC 填充方式:PKCS5 DBMS_CRYPTO.PAD_PKCS5 **************************************************/ V_KEY_RAW := UTL_I18N.STRING_TO_RAW(V_KEY,'UTF8') ; V_STR_RAW := UTL_I18N.STRING_TO_RAW(V_STR,'UTF8') ; V_TYPE := DBMS_CRYPTO.ENCRYPT_AES192+DBMS_CRYPTO.CHAIN_CBC+DBMS_CRYPTO.PAD_PKCS5 ; V_STR_RAW := DBMS_CRYPTO.ENCRYPT(SRC => V_STR_RAW , typ => V_TYPE, key => V_KEY_RAW) ; V_RETURN_STR := RAWTOHEX(V_STR_RAW); RETURN V_RETURN_STR ; /* EXCEPTION WHEN OTHERS THEN RETURN SQLERRM||SQLCODE ; */ END; -- 解密函数 CREATE OR REPLACE FUNCTION FUN_DECRYPTION( V_STR VARCHAR2 , V_KEY VARCHAR2 ) RETURN VARCHAR2 AS V_KEY_RAW RAW(24) ; V_STR_RAW RAW(2000) ; V_RETURN_STR VARCHAR2(2000) ; V_TYPE PLS_INTEGER ; BEGIN /************************************************ 解密函数 FUN_DECRYPTION 入参: V_STR 输入密文字符串,约定密文为16进制字符串 V_KEY 输入密钥字符串,长度为24字节 返回值: V_RETURN_STR 返回明文字符串 异常处理: 此函数不对任何异常做捕捉处理,请相应的程序模块对异常做捕捉处理。 加密方式: 密钥位数:AES192 DBMS_CRYPTO.ENCRYPT_AES192 连接方式:CBC DBMS_CRYPTO.CHAIN_CBC 填充方式:PKCS5 DBMS_CRYPTO.PAD_PKCS5 ***************************************************/ V_KEY_RAW := UTL_I18N.STRING_TO_RAW(V_KEY,'UTF8') ; V_STR_RAW := HEXTORAW(V_STR); V_TYPE := DBMS_CRYPTO.ENCRYPT_AES192+DBMS_CRYPTO.CHAIN_CBC+DBMS_CRYPTO.PAD_PKCS5 ; V_STR_RAW := DBMS_CRYPTO.DECRYPT(SRC => V_STR_RAW , typ => V_TYPE, key => V_KEY_RAW ) ; V_RETURN_STR := UTL_I18N.RAW_TO_CHAR(V_STR_RAW,'UTF8'); RETURN V_RETURN_STR ; /* EXCEPTION WHEN OTHERS THEN RETURN SQLERRM||SQLCODE ; */ END; |
相关文章推荐
- 强制删除DBF文件导致数据库报“ORA-01033: ORACLE 正在初始化或关闭”错误
- [转载]彻底卸载oracleXE数据库服务器
- Oracle OAF个性化一例 -- 个性化查询条件
- Oracle中作业(jobs)定时的调用
- Oracle正则表达式
- Oracle trunc()函数的用法
- oracle的正则表达式
- Oracle之物化视图
- linux 卸载oracle11g
- linux oracle 解决输入…
- oracle11g lsnrctl stat…
- oracle的LAG和LEAD分析函数
- Oracle 11g 修改中文字符集
- 老李分享:Oracle调优
- Oracle参数化查询
- 老李分享:Oracle数据库调优工具 2
- 老李分享:Oracle数据库调优工具
- Oracle Parameter: cpu_count¶llel_max_servers
- oracle rac 监听配置
- 聊聊Oracle 11g中的char类型使用