程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> Oracle中的MD5加密詳解,OracleMD5加密詳解

Oracle中的MD5加密詳解,OracleMD5加密詳解

編輯:Oracle教程

Oracle中的MD5加密詳解,OracleMD5加密詳解


一、技術點 

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;


怎把oracle數據庫中的密碼這一項的字段都改成MD5加密的

UPDATE table SET 密碼=MD5(密碼);
不知道oracle中有沒有,mysql中是存在的。
 

Oracle MD5加密,及java程序端的處理步驟

1:自己在oracle創建md5加密的function,代碼可以參考下面:

create or replace function MD5 (vin_string IN VARCHAR2)
RETURN VARCHAR2 IS
BEGIN
RETURN UPPER(Dbms_Obfuscation_Toolkit.Md5 ( input => utl_raw.cast_to_raw(vin_string) ));
END MD5

2:密碼均是以md5存儲的密文存在數據庫,匹配的時候也是密文比較一致性。無需解密,若解密,反而用戶不滿意了。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved