日期:2014-05-16 浏览次数:20436 次
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);