日期:2014-05-16  浏览次数:20420 次

学习如何使用oracle MD5加密

1.RAWTOHEX函数
rawtohex作用是将一个raw类型的值转换为hexadecimal.

举例:
HUNTER@finnet>select rawtohex('a') hex from dual;

HE
--
61

2.UTL_RAW.CAST_TO_RAW 的用法
主要作用是将一个字符类型的值转换为raw类型.

举例:
raw_input RAW(128) := UTL_RAW.CAST_TO_RAW(input_string);

3.sys.dbms_obfuscation_toolkit.MD5用法

语法如下

DBMS_OBFUSCATION_TOOLKIT.MD5(
?? input??????????? IN?? RAW,
?? checksum???????? OUT? raw_checksum);

DBMS_OBFUSCATION_TOOLKIT.MD5(
?? input_string???? IN?? VARCHAR2,
?? checksum_string? OUT? varchar2_checksum);

DBMS_OBFUSCATION_TOOLKIT.MD5(
?? input???????? IN? RAW)
? RETURN raw_checksum;

DBMS_OBFUSCATION_TOOLKIT.MD5(
?? input_string? IN? VARCHAR2)
? RETURN varchar2_checksum;

举例:
sys.dbms_obfuscation_toolkit.MD5(input => raw_input,checksum => decrypted_raw);


来个综合例子

CREATE OR REPLACE function fn_md5(input_string VARCHAR2) return varchar2
IS
raw_input RAW(128) := UTL_RAW.CAST_TO_RAW(input_string);
decrypted_raw RAW(2048);
error_in_input_buffer_length EXCEPTION;
BEGIN
sys.dbms_obfuscation_toolkit.MD5(input => raw_input,checksum => decrypted_raw);
return rawtohex(decrypted_raw);
END;

update t_user set password = fn_md5(password) where password is not null ;


此funcation可以完成初始化原来没有加md5加密的数据.

程序中使用如下

???? L_Password:=UPPER(PPassword);
???? p_rawinput := UTL_RAW.CAST_TO_RAW(L_Password);
???? sys.dbms_obfuscation_toolkit.MD5(input => p_rawinput,checksum => p_decrypted_raw);
???? L_Password := rawtohex(p_decrypted_raw);