我最近问了一个关于Oracle加密的问题。在为自己找到解决方案的过程中,我决定将加密(好吧,模糊处理)转移到应用程序端,以完成某些任务。
我的问题是,数据库已经在以某种方式加密数据,我需要Java代码来复制该功能,以便一个系统加密的文本可以被另一个系统解密,反之亦然。
我希望加密与数据库已经在做的事情兼容,但是找不到确切描述Oracle正在做什么的文档。我如何在Java中复制它?
dbms_obfuscation_toolkit.DESEncrypt(
input_string => v_string,
key_string => key_string,
encrypted_string => encrypted_string );
RETURN UTL_RAW.CAST_TO_RAW(encrypted_string);
不管我怎么尝试,Java DES加密似乎与Oracle的加密不同。
发布于 2008-09-22 07:30:57
我发现这是可行的:
KeySpec ks = new DESKeySpec(new byte[] {'s','e','c','r','e','t','!','!'});
SecretKeyFactory skf = SecretKeyFactory.getInstance("DES");
SecretKey sk = skf.generateSecret(ks);
Cipher c = Cipher.getInstance("DES/CBC/NoPadding");
IvParameterSpec ips = new IvParameterSpec(new byte[] {0,0,0,0,0,0,0,0});
c.init(Cipher.ENCRYPT, sk, ips);
// or
c.init(Cipher.DECRYPT, sk, ips);
缺少的部分是Initialization Vector (ips),它必须是8个零。当你在Java中使用null时,你会得到一些不同的东西。
发布于 2008-09-22 09:27:32
在数据库中使用Java将是另一种方法,它将(应该!)确保代码(以及结果)是相同的。
https://stackoverflow.com/questions/115503
复制