当前位置: 移动技术网 > IT编程>数据库>Oracle > Oracle中的MD5加密详解

Oracle中的MD5加密详解

2017年12月12日  | 移动技术网IT编程  | 我要评论

砸钱宝马女微博,村上西湖,淄博新闻频道

一、技术点 

1、 dbms_obfuscation_toolkit.md5
dbms_obfuscation_toolkit.md5是md5编码的数据包函数,但偶在使用select dbms_obfuscation_toolkit.md5(input_string =>'abc') a from dual时,却有错误提示,看来该函数只能直接在程序包中调用,不能直接应用于select语句。
  
2、utl_raw.cast_to_raw
dbms_obfuscation_toolkit.md5返回的字串,是raw类型,要正确显示,需要经过utl_raw.cast_to_raw转换

二、应用

1、直接调用

复制代码 代码如下:

declare
v2 varchar2(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、构造函数后,再调用

复制代码 代码如下:

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函数语句
create or replace function "md5hash" (str in varchar2)  
    return varchar2  
    is v_checksum varchar2(32);  
    
    begin 
        v_checksum := lower( rawtohex( utl_raw.cast_to_raw( sys.dbms_obfuscation_toolkit.md5(input_string => str) ) ) );  
        return v_checksum;  
        exception  
            when no_data_found then 
            null;  
        when others then 
            -- consider logging the error and then re-raise               raise;  
    end md5hash;

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网