java - 使用 DBMS_CRYPTO 但使用 dbms_obfuscation_toolkit 时出错
问题描述
捕获的 SQLException :: java.sql.SQLException: ORA-29532: Java 调用因未捕获的 Java 异常而终止:java.sql.SQLException: 无法获取服务器访问帐户详细信息:ORA-28817: PL/SQL 函数返回错误。
ORA-06512:在“SYS.DBMS_CRYPTO_FFI”,第 67 行
ORA-06512:在“SYS.DBMS_CRYPTO”,第 44 行
ORA-06512:在“NM.CIPHER”,第 41 行
ORA-06512:在“NM.DEVICE_ACCOUNT”,第 176 行
ORA-06512: 在第 1 行
ORA-06512: 在“NM.DEVICE_PROCEDURES”,第 8 行
ORA-06512: 在第 1 行
开发代码
create or replace PACKAGE BODY CIPHER IS
seven_bytes RAW(7) := HEXTORAW ('00000000000000');
FUNCTION make_8_bytes ( p_string IN RAW ) RETURN RAW IS
v_length PLS_INTEGER := MOD(utl_raw.length (p_string),8);
BEGIN
IF v_length = 0 THEN
RETURN p_string;
ELSE
RETURN utl_raw.concat (p_string,utl_raw.substr(seven_bytes,1,8-v_length));
END IF;
END;
FUNCTION encrypt ( p_string IN VARCHAR2,
p_key IN RAW ) RETURN RAW IS
encrypted_raw RAW(2048);
l_mod number := dbms_crypto.ENCRYPT_DES
+ dbms_crypto.CHAIN_CBC
+ dbms_crypto.PAD_PKCS5;
BEGIN
--dbms_obfuscation_toolkit.DESEncrypt(input => make_8_bytes (utl_raw.cast_to_raw(p_string)),key => make_8_bytes (p_key), encrypted_data => encrypted_raw );
encrypted_raw:= dbms_crypto.encrypt(src => make_8_bytes (utl_raw.cast_to_raw(p_string)),typ => l_mod, key => make_8_bytes (p_key));
RETURN encrypted_raw;
EXCEPTION
WHEN OTHERS THEN
v_errm:=SUBSTR(SQLERRM,1,200);
END;
FUNCTION decrypt ( p_string IN RAW,
p_key IN RAW ) RETURN VARCHAR2 IS
decrypted_raw RAW(2048);
l_ret varchar2 (2000);
l_mod number := dbms_crypto.ENCRYPT_DES
+ dbms_crypto.CHAIN_CBC
+ dbms_crypto.PAD_PKCS5;
BEGIN
-- dbms_obfuscation_toolkit.DESDecrypt(input => p_string,key => make_8_bytes (p_key), decrypted_data => decrypted_raw );
decrypted_raw:= dbms_crypto.Decrypt(src => p_string,typ => l_mod,key => make_8_bytes (p_key));
l_ret:= UTL_I18N.RAW_TO_CHAR(decrypted_raw, 'AL32UTF8');
RETURN l_ret;
--RETURN rtrim(utl_raw.cast_to_varchar2(decrypted_raw),chr(0));
EXCEPTION
WHEN OTHERS THEN
v_errm:=SUBSTR(SQLERRM,1,200);
END;
END CIPHER;
解决方案
我试过你的代码,结果是肯定的。
当我对 ENCRYPT 和 DECRYPT 使用不同的密钥时会引发错误。
请参见下面的示例:
ENCRYPT 和 DECRYPT 的相同键:
SELECT
CIPHER.DECRYPT(CIPHER.ENCRYPT('stackoverflow', UTL_RAW.CAST_TO_RAW('123')), UTL_RAW.CAST_TO_RAW('123'))
FROM
DUAL;
ENCRYPT 和 DECRYPT 的不同密钥:
SELECT
CIPHER.DECRYPT(CIPHER.ENCRYPT('stackoverflow', UTL_RAW.CAST_TO_RAW('123')), UTL_RAW.CAST_TO_RAW('1234'))
FROM
DUAL;
推荐阅读
- swift - 从sidemenu用户类型明智地删除索引
- javascript - 如何从 html 文本中找到类
- gnuplot - 轴端显示10的幂
- python - 如果 Python 文件出现在文本文件中,则读取文本文件(包含 Python 文件名列表)并终止 Python 作业
- vue.js - vue界面缺少$router
- ios - 如何知道 iOS 应用程序的大小
- asp.net - 在jQuery中获取表asp.net中选定行的表列值
- java - apache poi 工作簿写入尝试期间的 POIXMLException
- pentaho - 在 pentaho 数据集成中使用 java 8 特性(较新的 janino 版本)
- assembly - int 13h 返回 0x0C80