日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Oracle 加解密教程

發布時間:2023/12/15 综合教程 38 生活家
生活随笔 收集整理的這篇文章主要介紹了 Oracle 加解密教程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

參考Oracle官方文檔

在Oracle使用dbms_crypto包進行加解密

首先,授權當前用戶使用加解密包

在sql中運行:
connect sqlplus as sysdba
grant execute on sys.dbms_crypto to user;

dbms_crypto支持以下算法

DES,3DES(2-key and 3-ke)
AES,
MD5, MD4, SHA-1, and SHA-2 哈希算法
MAC (消息認證碼,Message authentication code)

支持的完整算法見:
https://docs.oracle.com/database/121/ARPLS/d_crypto.htm

oracle 數據加密和解密:

加密函數:

CREATE OR REPLACE FUNCTION ENCRYPT_FUNCTION1(
  V_STR        VARCHAR2, V_KEY VARCHAR2) RETURN VARCHAR2 AS V_KEY_RAW RAW(24);
  V_STR_RAW    RAW(2000);
  V_RETURN_STR VARCHAR2(2000);
  V_TYPE       PLS_INTEGER;
BEGIN
  /*************************************************
    加密函數 FUN_ENCRYPTION 
        入參:
          V_STR 輸入明文字符串
          V_KEY 輸入密鑰字符串,長度為24字節
        返回值:
          V_RETURN_STR 返回密文字符串,約定返回為 16進制密文字符串
        異常處理:
          此函數不對任何異常做捕捉處理,請相應的程序模塊對異常做捕捉處理。

        加密方式:
          密鑰位數:AES192   DBMS_CRYPTO.ENCRYPT_AES192
          連接方式:CBC      DBMS_CRYPTO.CHAIN_CBC
          填充方式:PKCS5    DBMS_CRYPTO.PAD_PKCS5

  **************************************************/
  V_KEY_RAW    := UTL_I18N.STRING_TO_RAW(V_KEY, 'ZHS16GBK');
  V_STR_RAW    := UTL_I18N.STRING_TO_RAW(V_STR, 'ZHS16GBK');
  -- 指定‘密鑰算法’、‘工作模式’、‘填充方式’
  V_TYPE       := DBMS_CRYPTO.ENCRYPT_DES + DBMS_CRYPTO.CHAIN_ECB +
                  DBMS_CRYPTO.PAD_PKCS5;
  V_STR_RAW    := DBMS_CRYPTO.ENCRYPT(SRC => V_STR_RAW,
                                      TYP => V_TYPE,
                                      KEY => V_KEY_RAW);
  V_RETURN_STR := RAWTOHEX(V_STR_RAW);
  RETURN V_RETURN_STR;

  /* EXCEPTION
  WHEN OTHERS THEN
  RETURN SQLERRM||SQLCODE ;   */
END;

解密函數:

CREATE OR REPLACE FUNCTION DECRYPT_FUNCTION1(V_STR VARCHAR2, V_KEY VARCHAR2)
  RETURN VARCHAR2 AS
  V_KEY_RAW    RAW(24);
  V_STR_RAW    RAW(2000);
  V_RETURN_STR VARCHAR2(2000);
  V_TYPE       PLS_INTEGER;

BEGIN
  /************************************************
     解密函數 FUN_DECRYPTION 
        入參:
          V_STR 輸入密文字符串,約定密文為16進制字符串
          V_KEY 輸入密鑰字符串,長度為24字節
        返回值:
          V_RETURN_STR 返回明文字符串
        異常處理:
          此函數不對任何異常做捕捉處理,請相應的程序模塊對異常做捕捉處理。

        加密方式:
          密鑰位數:AES192   DBMS_CRYPTO.ENCRYPT_AES192
          連接方式:CBC      DBMS_CRYPTO.CHAIN_CBC
          填充方式:PKCS5    DBMS_CRYPTO.PAD_PKCS5

  ***************************************************/
  V_KEY_RAW := UTL_I18N.STRING_TO_RAW(V_KEY, 'ZHS16GBK');
  V_STR_RAW := HEXTORAW(V_STR);
  -- 指定‘密鑰算法’、‘工作模式’、‘填充方式’
  V_TYPE       := DBMS_CRYPTO.ENCRYPT_DES + DBMS_CRYPTO.CHAIN_ECB +
                  DBMS_CRYPTO.PAD_PKCS5;
  V_STR_RAW    := DBMS_CRYPTO.DECRYPT(SRC => V_STR_RAW,
                                      TYP => V_TYPE,
                                      KEY => V_KEY_RAW);
  V_RETURN_STR := UTL_I18N.RAW_TO_CHAR(V_STR_RAW, 'ZHS16GBK');
  RETURN V_RETURN_STR;
  /*  EXCEPTION
  WHEN OTHERS THEN
  RETURN SQLERRM||SQLCODE ; */
END;

調用加密的函數:

CREATE OR REPLACE FUNCTION MYENCODE(STR IN VARCHAR2) RETURN VARCHAR2 IS

BEGIN
if STR is null then
  return '';
end if;
if STR='' then
  return '';
end if;
//ENCRYPT_FUNCTION1上面的加密函數 RETURN utl_raw.cast_to_varchar2(utl_encode.base64_encode(utl_raw.cast_to_raw(ENCRYPT_FUNCTION1(str,'siweicn1234')))); END MYENCODE;

調用解密的函數:

CREATE OR REPLACE FUNCTION MYDECODE(STR IN VARCHAR2) RETURN VARCHAR2 IS

BEGIN
if STR is null then
  return '';
end if;
if STR='' then
  return '';
end if;
//DECRYPT_FUNCTION1上面的解密函數 RETURN DECRYPT_FUNCTION1(utl_raw.cast_to_varchar2(utl_encode.base64_decode(utl_raw.cast_to_raw(str))),'siweicn1234'); END MYDECODE;

測試加密函數:

測試解密函數:

總結

以上是生活随笔為你收集整理的Oracle 加解密教程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日日操日日| 秋霞在线一区 | av操操 | 搞黄视频在线观看 | 视频在线观看网站免费 | 在线观看视频一区二区 | 97人妻天天摸天天爽天天 | 精品福利一区 | v在线| 亚洲av无码国产精品久久不卡 | jizz日本女人 | 奶水喷溅 在线播放 | 国产偷人妻精品一区 | 可以在线观看av的网站 | av网站观看| 久久都是精品 | 国产精品久久久久9999 | 日韩欧美一区二区一幕 | 欧美成人综合 | 久草视频免费看 | 国产一级影片 | 黄色日韩在线 | 少妇欧美激情一区二区三区 | 久久99精品国产91久久来源 | 大香伊人 | 99欧美精品 | 婷婷久久久久久 | 在线精品国产 | 99精品视频网站 | 闺蜜张开腿让我爽了一夜 | 亚洲国产精品麻豆 | 亚洲无人禁区 | 激情五月亚洲 | 欧美变态口味重另类在线视频 | 性a视频 | 日韩aaa| 国产专区自拍 | 成人在线a | 亚洲色图17p| 中文字幕在线免费观看视频 | 波多野结衣中文字幕一区二区三区 | 人妻内射一区二区在线视频 | 国产精品久久久一区二区三区 | 国产suv一区二区 | 国产激情综合 | 成人97| 怡红院成人在线 | av无码精品一区二区三区 | 欧美黄片一区二区三区 | 好大好爽视频 | 国产精品永久久久久久久久久 | 日本老太婆做爰视频 | 狠狠久久久 | 一区二区三区激情 | 亚洲欧美成人一区 | 亚洲欧美另类中文字幕 | 免费性爱视频 | 国产一区亚洲二区 | 国产不卡在线视频 | 无码人妻精品一区二区三区蜜桃91 | 尤物自拍 | 一级黄色性片 | 波多野结衣一区二区三区在线观看 | 9.1成人看片免费版 日韩经典在线 | 国产精品自拍合集 | 欧美变态绿帽cuckold | 中文字幕第一页av | 日韩伦理一区二区三区 | 欧美一级淫片免费视频黄 | 深田咏美在线x99av | 波多av在线 | 亚洲美女精品 | 国产精品成人无码 | 免费一级a毛片 | 香蕉视频性 | 日韩永久免费视频 | 在线看欧美| 一级做a爱视频 | 国产三区四区视频 | 熟女性饥渴一区二区三区 | 亚洲av成人精品日韩在线播放 | 中文字幕在线视频不卡 | 国产精品无码网站 | a黄色片 | 不卡视频在线观看免费 | 美女扒开大腿让男人桶 | 欧美xxx性| 欧美日韩亚洲色图 | 超碰2025| wwwxx国产| 久久亚洲综合色 | 亚洲国产精品女人久久久 | 香蕉视频黄在线观看 | 成人免费视频网站在线观看 | 91精品国自产在线偷拍蜜桃 | 丰满人妻一区二区三区精品高清 | 在线免费av网址 | 91在线免费网站 | 一区二区三区精品免费视频 |