国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

Oracle中的MD5加密詳解

2024-08-29 13:58:15
字體:
來源:轉載
供稿:網友
MD5是我們常用的一種加密方式,在各個方面都有用到這個加密方式,今天我們來探討下在Oracle中如何使用MD5加密
 
 

一、技術點 

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;
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 利津县| 云龙县| 浙江省| 海原县| 菏泽市| 临洮县| 济源市| 高台县| 蒙山县| 财经| 九江县| 峨眉山市| 肃宁县| 吴桥县| 筠连县| 弥勒县| 塘沽区| 南平市| 伊川县| 南部县| 沁阳市| 左贡县| 南靖县| 莒南县| 英吉沙县| 孟村| 西平县| 孟津县| 宝应县| 武安市| 卢湾区| 洪泽县| 南平市| 临桂县| 晋宁县| 台山市| 瓦房店市| 梅河口市| 武胜县| 湟源县| 松江区|