OracleAES加密 (2012-04-29 21:52:15)转载▼
标签: oracle aes 加密 it 分类: 开发
-- 加密函数
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

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 ;

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

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 ;

END;

最新文章

  1. 用RMAN备份EBS数据库的脚本
  2. MySQL存储IP地址操作
  3. 不谈业务运维的IT主管早晚被淘汰 这里是10条干货
  4. mysql 插入/更新数据
  5. sqlserver临时表操作
  6. mysql 数据库备份
  7. jar包和war包的区别(转)
  8. if for case 及多参数同时传递
  9. Python超级程序员使用的开发工具
  10. Person
  11. IFrame 根据嵌入页面自动调节大小
  12. 使用javah生成.h文件, 出现无法访问android.app,Activity的错误的解决
  13. android 高效显示Bitmap - 开发文档翻译
  14. Android启动第三方应用程序
  15. 详解JS对象
  16. C#8.0可空引用类型的使用注意要点
  17. python 正则指北之我的总结
  18. 初试fiddler
  19. CPU利用率和CPU负荷(CPU usage vs CPU load)
  20. 1004 Counting Leaves 对于树的存储方式的回顾

热门文章

  1. IPv6地址测试宏
  2. 梯度下降算法对比(批量下降/随机下降/mini-batch)
  3. Access数据库SQL注入(Access SQL Injection)
  4. Restful API学习Day5 - DRF之限制 分页 解析器和渲染器
  5. ES6走一波 Iterator
  6. ES6走一波 Proxy/Reflect
  7. 【tmos】mvn package相关知识点(待补充...)
  8. linux一些比较重要的环境变量。配置文件
  9. mysql 原理 ~ 死锁问题
  10. Javascript - ExtJs - 弹窗