php数据库加密不导出,加密的数据在导出,再导入后,大多无法解密了,有谁能够帮助?...

ORACLE 10G数据库,对数据库中某表的地址(varchar2  1024)与电话(varchar2  64)进行加密,用的加密函数如下:

create or replace function encrypt_data(p_text varchar2, p_key varchar2) return varchar2 is

v_text varchar2(4000);

v_enc varchar2(4000);

begin

if p_text is null then

return null;

else

v_text := rpad(p_text, (trunc(lengthb(p_text)/8)+1)*8, chr(0));

sys.dbms_obfuscation_toolkit.desencrypt(

input_string => v_text,

key_string => p_key,

encrypted_string=>v_enc);

return v_enc;

end if;

end;

/

create or replace function decrypt_data(p_text varchar2, p_key varchar2) return varchar2 is

v_text varchar2(4000);

begin

if p_text is null then

return null;

else

sys.dbms_obfuscation_toolkit.desdecrypt(

input_string => p_text,

key_string => p_key,

decrypted_string=> v_text);

return rtrim(v_text,chr(0));

end if;

end;

/

正常加密后,解密是可以用的。但在把数据库导出,并且在另一台数据库10G服务器导入后,绝大多数数据不能解密。报:

ORA-28232: obfuscation 工具箱的输入长度无效

ORA-06512: 在 "SYS.DBMS_OBFUSCATION_TOOLKIT_FFI", line 40

ORA-06512: 在 "SYS.DBMS_OBFUSCATION_TOOLKIT", line 153

ORA-06512: 在 "WEBSITE.DECRYPT_DATA", line 7

偶尔有一两个字可以解密。

查看了数据库表中的数据,能够解析的,转换后的值相同,如,

原始数据:

747233        北京市朝阳区光华路7号汉威大厦B802        65612776

加密后的,导出再导入后都为下面值:

747233        g踣

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值