Oracle中的MD5加密详解
一、技术点
1、DBMS_OBFUSCATION_TOOLKIT.MD5
DBMS_OBFUSCATION_TOOLKIT.MD5是MD5编码的数据包函数,但偶在使用selectDBMS_OBFUSCATION_TOOLKIT.MD5(input_string=>'abc')afromDual时,却有错误提示,看来该函数只能直接在程序包中调用,不能直接应用于SELECT语句。
2、Utl_Raw.Cast_To_Raw
DBMS_OBFUSCATION_TOOLKIT.MD5返回的字串,是RAW类型,要正确显示,需要经过Utl_Raw.Cast_To_Raw转换
二、应用
1、直接调用
declare v2varchar2(32);begin v2:=Utl_Raw.Cast_To_Raw(sys.dbms_obfuscation_toolkit.md5(input_string=>'111')); dbms_output.put_line(v2);end;
注意:可以在存储过程中直接调用,如果要嵌套调用md5时,记得每次调用后都用Utl_Raw.Cast_To_Raw进行转换,否则最后出来的结果是错误的。
2、构造函数后,再调用
CREATEORREPLACEFUNCTIONMD5( passwdINVARCHAR2)RETURNVARCHAR2IS retvalvarchar2(32);BEGIN retval:=utl_raw.cast_to_raw(DBMS_OBFUSCATION_TOOLKIT.MD5(INPUT_STRING=>passwd));RETURNretval;END;
调用md5函数示例:
selectmd5(1)fromdual
另附:Oracle中MD5函数语句
--Oracle中MD5函数语句 createorreplaceFUNCTION"MD5HASH"(strINVARCHAR2) RETURNVARCHAR2 ISv_checksumVARCHAR2(32); BEGIN v_checksum:=LOWER(RAWTOHEX(UTL_RAW.CAST_TO_RAW(sys.dbms_obfuscation_toolkit.md5(input_string=>str)))); RETURNv_checksum; EXCEPTION WHENNO_DATA_FOUNDTHEN NULL; WHENOTHERSTHEN --Considerloggingtheerrorandthenre-raise RAISE; ENDmd5hash;