首页 / 数据库 / MySQL / Oracle中的MD5加密
因为要用到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")的结果是:69616D6C616F736F6E67utl_raw.cast_to_raw("我是老宋")的结果是:CED2CAC7C0CFCBCE MD5包函数的使用方法如下:1、直接调用declarev2 varchar2(32);beginv2 := 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 VARCHAR2ISretval varchar2(32);BEGINretval := utl_raw.cast_to_raw(DBMS_OBFUSCATION_TOOLKIT.MD5(INPUT_STRING => passwd)) ;RETURN retval;END;调用md5函数示例:select md5(1) from dual更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12本文永久更新链接地址