oracle加密-des 简单举例.
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 简单举例.的更多相关文章
- Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍
引用自 :http://www.2cto.com/database/201307/224836.html Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...
- Asp.Net 常用工具类之加密——对称加密DES算法(2)
又到周末,下午博客园看了两篇文章,关于老跳和老赵的程序员生涯,不禁感叹漫漫程序路,何去何从兮! 转眼毕业的第三个年头,去过苏州,跑过上海,从一开始的凌云壮志,去年背起行囊默默回到了长沙准备买房,也想有 ...
- [转]bootstrapTable refresh 方法使用简单举例
原文地址:https://blog.csdn.net/lanyang123456/article/details/55805478 本文就bootstrapTable refresh 方法如何传递参数 ...
- bootstrapTable refresh 方法使用简单举例
本文就bootstrapTable refresh 方法如何传递参数做简单举例说明. 下面代码中,一个table,一个button,单击button会触发刷新表格操作. <!DOCTYPE ht ...
- 对称加密DES加密
DES加密: des是对称加密,加密和解密需要相同的秘钥,它的密码最长56位,必须是8的倍数,秘钥越长,越安全. package com.trm.util.encrypt; import java.s ...
- Java中使用MD5加密的简单实现
import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorith ...
- oracle加密encrypt,解密decrypt
目录 oracle加密encrypt,解密decrypt 加密 解密 oracle加密encrypt,解密decrypt 有的oracle版本没有加解密函数,以下操作可以手动添加 oracle数据使用 ...
- 备忘DES带向量的加密和解密与DES简单加密与解密
package com.ego.util; import java.security.Key; import java.security.SecureRandom; import java.secur ...
- 备忘DES简单加密与解密
package com.ego.util; import java.io.IOException; import java.security.SecureRandom; import javax.cr ...
随机推荐
- kendoui仪表盘和柱状图 示例
一说到kendeodui我相信大家一定不陌生,这套js在画图方面效果也不错. 现在来看一看 仪表盘和柱状图的效果吧: html和js代码如下: <!DOCTYPE html> <ht ...
- 机器学习、NLP、Python和Math最好的150余个教程(建议收藏)
编辑 | MingMing 尽管机器学习的历史可以追溯到1959年,但目前,这个领域正以前所未有的速度发展.最近,我一直在网上寻找关于机器学习和NLP各方面的好资源,为了帮助到和我有相同需求的人,我整 ...
- 老猪带你玩转android自定义控件二——自定义索引栏listview
带索引栏的listview,在android开发非常普遍,方便用户进行字母索引,就像微信通讯录这样: 今天,我们就从零到一实现这个具有索引栏的listview. 怎么实现这个控件了,我们应当梳理出一个 ...
- xgboost入门与实战
xgboost入门与实战(实战调参篇) https://blog.csdn.net/sb19931201/article/details/52577592 前言 前面几篇博文都在学习原理知识,是时候上 ...
- Kafka:ZK+Kafka+Spark Streaming集群环境搭建(七)针对hadoop2.9.0启动DataManager失败问题
DataManager启动失败 启动过程中发现一个问题:slave1,slave2,slave3都是只启动了DataNode,而DataManager并没有启动: [spark@slave1 hado ...
- 关于ThinkPhp中getField方法存在的问题
在ThinkPhp中我们可以通过以下方式获取数据库数据 query:直接执行SQL查询操作 find:查询单选数据集 getField查询字段值 select:查询数据集 其他...... 但今天 ...
- CSS中的图片路径问题
CSS中的背景图片写了相对路径,为什么不显示那? [解决方法] CSS中的背景图片路径应该写成相对于当前CSS文件的路径,而不是针对网站根目录的相对路径.
- form表单自动回车提交
对于使用了submit按钮的form表单,浏览器会直接建立回车与submit按钮之间的关联
- Material Design学习之 ProgreesBar
转载奇怪注明出处:王亟亟的大牛之路 继续我们Material Design的内容,这一篇讲的是进度条,上一篇是Switch地址例如以下:http://blog.csdn.net/ddwhan0123/ ...
- 被查封7周之后,全球最大BT网站“海盗湾”又重新活过来了【36kr】
原文地址 原文地址 "免费"和"版权","自由"和"监管"永远在较量啊,矛盾共同体,事物的两面性~ 被查封7周之后,全球 ...