我正在使用 Jasypt 加密库来加密/解密一些文本。此代码嵌入在 WAR 文件中并部署到服务器。
在本地运行和单元测试时,加密/解密周期完美运行。我使用 Jetty 来开发应用程序。该代码在该服务器中完美运行。出于某种原因,部署到 Tomcat 会破坏它,但有以下例外:
仅供参考,我在本地和服务器环境中都安装了强加密库,并且我使用的是最新的 1.6 版本(补丁级别 25)。
org.jasypt.exceptions.EncryptionOperationNotPossibleException
异常没有消息。
代码是完全对称的。我把它贴在这里供检查。以下是相关位:
我发现了一篇旧的 Nabble 帖子,其中一位用户遇到了非常相似的问题。代码在任何地方都可以工作,除了 Tomcat 内部。没有给出解决方案。
任何见解将不胜感激。
**更新:** 在我的本地系统上的 Tomcat 中运行,它似乎可以工作。所以我的服务器有些东西。在服务器上,我在 Windows Server 2008 上使用 64 位 JVM。我在本地使用 32 位 JVM(由于我的系统有点旧)。我想知道这是否与这个问题有关。
public void initializeService() {
binaryEncryptor = new BasicBinaryEncryptor();
binaryEncryptor.setPassword(keyBase64);
}
@Override
public <T extends Serializable> String simpleEncrypt(T objectToEncrypt) throws EncryptionException {
ByteArrayOutputStream bos = new ByteArrayOutputStream();
try {
ObjectOutputStream oos = new ObjectOutputStream(bos);
oos.writeObject(objectToEncrypt);
byte[] bytes = binaryEncryptor.encrypt(bos.toByteArray());
return new String(Base64.encodeBase64(bytes));
} catch (IOException e) {
LOGGER.error("failed to encrypt String: " + e.getMessage());
throw new EncryptionException(e.getMessage(), e);
} catch (Exception e) {
LOGGER.error("failed to encrypt String: " + e.getMessage());
throw new EncryptionException(e.getMessage(), e);
}
};
@SuppressWarnings("unchecked")
@Override
public <T> T simpleDecrypt(String objectToDecrypt) throws EncryptionException {
try {
byte[] bytes = Base64.decodeBase64(objectToDecrypt);
byte[] decryptedBytes = binaryEncryptor.decrypt(bytes);
ObjectInputStream ois = new ObjectInputStream(new ByteArrayInputStream(decryptedBytes));
T object = (T)ois.readObject();
return object;
} catch (IOException e) {
LOGGER.error("failed to decrypt String: '" + objectToDecrypt + "', mesage = " + e.getMessage());
throw new EncryptionException(e.getMessage(), e);
} catch (Exception e) {
LOGGER.error("failed to decrypt String: '" + objectToDecrypt + "', mesage = " + e.getMessage());
throw new EncryptionException(e.getMessage(), e);
}
}