Declare
  v_seed Raw(128);
  v_key_1 Raw(64);
  v_key_2 Raw(64);
 
  v_Text_for_encrypted Raw(64);
  v_mw  Raw(64);
  v_cleartext Raw(64);
Begin
   --128位种子,产生密匙
   v_seed:=utl_raw.cast_to_raw('goognightgooddayadkajdfkladjfa;kf;akjdfakd;fadfadfaoeifakdjfakdjfafdafadfaf34343434343434343434343434343434343434343434343434343');  
   dbms_obfuscation_toolkit.DESGetKey(seed => v_seed,key => v_key_1);
   dbms_output.put_line(utl_raw.cast_to_varchar2(v_key_1));
  
   --用密匙加密明文
   v_text_for_encrypted:=utl_raw.cast_to_raw('China is a great country');
   dbms_obfuscation_toolkit.DESEncrypt(input =>v_text_for_encrypted ,key => v_key_1,encrypted_data =>v_mw );
   dbms_output.put_line(v_mw);
  
   --用密匙 解密 密文
   dbms_obfuscation_toolkit.DESDecrypt(input =>v_mw ,key =>v_key_1 ,decrypted_data =>v_cleartext );
   dbms_output.put_line(utl_raw.cast_to_varchar2(v_cleartext));
  
   ---des-3算法测试
   dbms_obfuscation_toolkit.DES3GetKey(which => 0,seed => v_seed,key => v_key_1);
   dbms_output.put_line(utl_raw.cast_to_varchar2(v_key_1));
  
   dbms_obfuscation_toolkit.DES3Encrypt(input =>v_text_for_encrypted ,key =>v_key_1 ,encrypted_data =>v_mw ,which => 0,iv =>Null);
  
   dbms_obfuscation_toolkit.DES3Decrypt(input => v_mw,key =>v_key_1,decrypted_data =>v_cleartext,which => 0,iv => Null);
   dbms_output.put_line(utl_raw.cast_to_varchar2(v_cleartext));
  
   
End;  


输出如下:
   7埓K束觿
8332BE58695F720C4563BAD4CDAACAF687F9A3461B779D7C
China is a great country
x埮>豌h@?镵A.7
China is a great country


 关于des3算法,请参考oracle <<PL/SQL Packages and Types Reference>>



2009/10/23 补充如下:
1)如果在其它的应用环境中调用以上过程方法,那么请务必注意变量处理的问题,否则可能导致无法正确地解密
2)对于不同的oracle实例,其密匙都需要重新生成的。

有两个函数:

 create or replace function func_des3_JiaMi(ClearText  in varchar2) return Varchar2 Is
/*-----------------------------------------------------------------------
  名称:    
  功能简述:对传入的密码进行加密
  参数:
       Ename   Cname   availableValue     
       pwdd    密码
  返回:
       明文密码
  算法:
       DES-3
  注意事项:
       1)对于明文,必须是8的倍数,由于这里是加密密码的,所以,暂时算有24位。
       2)对于key而言,不同的时间产生的不一样的,不同机器产生的也不能混用,所以可以使用其它方法生成一个
         key之后,再代入到以下代码中。
  数据源:
       
  修改记录;
  lzf     2009-10-20     新增
*/  
  --v_seed Raw(128);
  v_key_1 Raw(64);
  vTmp   Varchar2(24):=rpad(ClearText,24,' ');
  --vTmp   Varchar2(24):=ClearText;
  v_cleartext Raw(64);
  v_mw  Raw(64);
Begin
   --128位种子
 --v_seed:=utl_raw.cast_to_raw('riceWaterMeatMilkOrangeAppleBananaVegetableChickenDeskPaperInkCupTeaOilGasKnifeGunSexAgeNiceGirlBeautifulCarBusFatherGoodChinese');      
   --des-3 ,产生密匙
   --dbms_obfuscation_toolkit.DES3GetKey(which => 0,seed => v_seed,key => v_key_1);      
   --des-3-加密      
   v_key_1:=utl_raw.cast_to_raw('$?ⅣU7覡q詹m?.');
   v_cleartext:=utl_raw.cast_to_raw(vTmp);
   dbms_obfuscation_toolkit.DES3Encrypt(input =>v_cleartext ,key =>v_key_1 ,encrypted_data =>v_mw ,which => 0,iv =>Null);
   Return  utl_raw.cast_to_varchar2(v_mw);
   --Return v_mw;
exception
  when others Then
     dbms_output.put_line(Sqlerrm);
     return null;  
end func_des3_JiaMi;
 create or replace function func_des3_JieMi(pwd  in Varchar2) return varchar2 Is
/*-----------------------------------------------------------------------
  名称:    function func_des3_JieMi
  功能简述:对传入的密码进行解密
  参数:
       Ename   Cname   availableValue     
       pwdd    密码
  返回:
       明文密码
  算法:
       DES-3
  注意事项:
     pwd必须是varchar2格式,不是raw格式.  
  数据源:
       
  修改记录;
  lzf     2009-10-20     新增
*/  
  --v_seed Raw(128);
  v_key_1 Raw(64);
  v_cleartext Raw(64);
  v_mw   Raw(64):=utl_raw.cast_to_raw(pwd);
  --v_mw   Raw(64):=pwd;
Begin

   --128位种子
   --v_seed:=utl_raw.cast_to_raw('riceWaterMeatMilkOrangeAppleBananaVegetableChickenDeskPaperInkCupTeaOilGasKnifeGunSexAgeNiceGirlBeautifulCarBusFatherGoodChinese');    
   ---des-3 ,产生密匙
   --dbms_obfuscation_toolkit.DES3GetKey(which => 0,seed => v_seed,key => v_key_1);      
   --des-3-解密   
   v_key_1:=utl_raw.cast_to_raw('$?ⅣU7覡q詹m?.');
   dbms_obfuscation_toolkit.DES3Decrypt(input => v_mw,key =>v_key_1,decrypted_data =>v_cleartext,which => 0,iv => Null);  
   Return  utl_raw.cast_to_varchar2(v_cleartext);
exception
  when others then
     return null;  
end function func_des3_JieMi;
/

oracle加密-des 简单举例.的更多相关文章

  1. Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍

    引用自 :http://www.2cto.com/database/201307/224836.html   Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...

  2. Asp.Net 常用工具类之加密——对称加密DES算法(2)

    又到周末,下午博客园看了两篇文章,关于老跳和老赵的程序员生涯,不禁感叹漫漫程序路,何去何从兮! 转眼毕业的第三个年头,去过苏州,跑过上海,从一开始的凌云壮志,去年背起行囊默默回到了长沙准备买房,也想有 ...

  3. [转]bootstrapTable refresh 方法使用简单举例

    原文地址:https://blog.csdn.net/lanyang123456/article/details/55805478 本文就bootstrapTable refresh 方法如何传递参数 ...

  4. bootstrapTable refresh 方法使用简单举例

    本文就bootstrapTable refresh 方法如何传递参数做简单举例说明. 下面代码中,一个table,一个button,单击button会触发刷新表格操作. <!DOCTYPE ht ...

  5. 对称加密DES加密

    DES加密: des是对称加密,加密和解密需要相同的秘钥,它的密码最长56位,必须是8的倍数,秘钥越长,越安全. package com.trm.util.encrypt; import java.s ...

  6. Java中使用MD5加密的简单实现

    import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorith ...

  7. oracle加密encrypt,解密decrypt

    目录 oracle加密encrypt,解密decrypt 加密 解密 oracle加密encrypt,解密decrypt 有的oracle版本没有加解密函数,以下操作可以手动添加 oracle数据使用 ...

  8. 备忘DES带向量的加密和解密与DES简单加密与解密

    package com.ego.util; import java.security.Key; import java.security.SecureRandom; import java.secur ...

  9. 备忘DES简单加密与解密

    package com.ego.util; import java.io.IOException; import java.security.SecureRandom; import javax.cr ...

随机推荐

  1. c#利用SWIG调用c++dll学习总结【转】

    开发环境: 操作系统:windows 7 IDE:Microsoft Visual Studio Professional 2015 SWIG: 3.0.12 swig的介绍 详细介绍可看官网,一下贴 ...

  2. SVN服务器搭建和使用(转)

    Subversion是优秀的版本控制工具,其具体的的优点和详细介绍,这里就不再多说. 首先来下载和搭建SVN服务器. 现在Subversion已经迁移到apache网站上了,下载地址: http:// ...

  3. windows钩子(转)

    1. 消息钩子 提示: 如果要设置系统级钩子, 钩子函数必须在 DLL 中. SetWindowsHookEx(   idHook: Integer;  {钩子类型}   lpfn: TFNHookP ...

  4. CentOS6 安装并破解Jira 7

    CentOS6 安装并破解Jira 7 JIRA软件是为您的软件团队的每个成员构建的,用来规划,跟踪和发布优秀的软件. https://confluence.atlassian.... 最低硬件要求及 ...

  5. json字符串转JSONObject和JSONArray以及取值

    import net.sf.json.JSONArray; import net.sf.json.JSONObject; public class JsonTest { public static v ...

  6. Laravel 5.5 使用 Jwt-Auth 实现 API 用户认证以及刷新访问令牌

    最近在做一个公司的项目,前端使用 Vue.js,后端使用 Laravel 构建 Api 服务,用户认证的包本来是想用 Laravel Passport 的,但是感觉有点麻烦,于是使用了 jwt-aut ...

  7. 【Spark】SparkStreaming-提交到集群运行

    SparkStreaming-提交到集群运行 spark streaming 提交_百度搜索 SparkStreaming示例在集群中运行 - CSDN博客

  8. Word Embedding与Word2Vec

    http://blog.csdn.net/baimafujinji/article/details/77836142 一.数学上的“嵌入”(Embedding) Embed这个词,英文的释义为, fi ...

  9. List 多次排序

    List<Patientmain> list = patientmains.OrderBy(p => p.Firstname).ThenBy(p => p.Middlename ...

  10. Java-JUC(七):同步锁的几种方式

    为什么要使用同步锁? 因为当使用多线程同时访问一个变量或对象时,如果这些线程中即有读又有写操作时,会造成导致变量或对象的状态出现混乱.例如:一个银行账户被A/B两个线程同时操作,A线程.B线程同时开始 ...