首页 / ORACLE / Oracle中的MD5加密
Oracle中的MD5加密
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Oracle中的MD5加密,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1879字,纯文字阅读大概需要3分钟。
内容图文
![Oracle中的MD5加密](/upload/InfoBanner/zyjiaocheng/563/3fbf52f4793a462382ab4868f4d9a55c.jpg)
因为要用到MD5加密,所以在网上搜了一下相关资料,并进行仔细研究。其核心就是MD5编码的数据包函数:DBMS_OBFUSCATION_TOOLKIT.M
因为要用到MD5加密,所以在网上搜了一下相关资料,并进行仔细研究。其核心就是MD5编码的数据包函数:DBMS_OBFUSCATION_TOOLKIT.MD5,这里涉及到RAW类型,其实就是原始的代码值。
MD5加密的结果就是16个byte值,也就是是RAW类型,是显示不出来的,要正确显示,需要经过Utl_Raw.Cast_To_Raw转换,这个函数的作用是将每个字节的值用十六进制字符表示出来。为了说明清楚,举例如下:假定一个字节的二进制值是0100 0001,十六进制表示就是41(这个值实际上就是字母“A”的ASCII代码值,硬要显示,还是可以显示出A来的,但有些非ASCII码的值就显示不出来了,比如1100 0001,十六进制表示就是C1),那么经过Utl_Raw.Cast_To_Raw转换后就变成了字符串“41”。
Utl_Raw.Cast_To_Raw函数也可以转换字符串,也就是将字符串的代码值(应该是Oracle字符集内码)以十六进制表示出来,例如:
utl_raw.cast_to_raw('iamlaosong')的结果是:69616D6C616F736F6E67
utl_raw.cast_to_raw('我是老宋')的结果是:CED2CAC7C0CFCBCE
MD5包函数的使用方法如下:
1、直接调用
declare
v2 varchar2(32);
begin
v2 := Utl_Raw.Cast_To_Raw(sys.dbms_obfuscation_toolkit.md5(input_string => '123456'));
dbms_output.put_line(v2);
end;
显示结果:E10ADC3949BA59ABBE56E057F20F883E
这个字符串实际上是16个字节的值用十六进制表示的结果,其中的字符是0-9和A-F,,正因为如此,其中的字母大小写是无关的,都表示同一个值。
再举个例子,字符串:iamlaosong,加密后显示的结果:7E0FB497D8C4515157DDEAFC2E511290,很显然,也是16个字节的十六进制表示。
至于加密结果的比较,还是转换成字符串后较为直观,比较起来也方便一些。
2、构造函数后,再调用
CREATE OR REPLACE FUNCTION MD5(
passwd IN VARCHAR2)
RETURN VARCHAR2
IS
retval varchar2(32);
BEGIN
retval := utl_raw.cast_to_raw(DBMS_OBFUSCATION_TOOLKIT.MD5(INPUT_STRING => passwd)) ;
RETURN retval;
END;
调用md5函数示例:
select md5(1) from dual
本文永久更新链接地址:
内容总结
以上是互联网集市为您收集整理的Oracle中的MD5加密全部内容,希望文章能够帮你解决Oracle中的MD5加密所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。