源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Oracle中的MD5加密详解

  • 时间:2022-10-01 10:31 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要: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、直接调用
[u]复制代码[/u] 代码如下:
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、构造函数后,再调用
[u]复制代码[/u] 代码如下:
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函数示例:
[u]复制代码[/u] 代码如下:
select md5(1) from dual
另附:Oracle中MD5函数语句
[u]复制代码[/u] 代码如下:
--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;
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部