java - 使用 Java/Jackcess 从加密的 Access .mdb 中读取

标签 java encryption ucanaccess jackcess ms-access-97

我需要从加密的 Access 97 数据库中读取数据并试用了 Jackcess 和 UCanAccess。

我正在使用来自 bouncycaSTLe.org 的 jackcess-2.1.2.jar、jackcess-encrypt-2.1.0 和 bcprov-jdk15on-152.jar

由于 UCanAccess 在内部使用 Jackcess,我在所有其他尝试中都遇到了同样的错误。

import com.healthmarketscience.jackcess.CryptCodecProvider;
import com.healthmarketscience.jackcess.Database;
import com.healthmarketscience.jackcess.DatabaseBuilder;
import java.io.File;

File fi = new File("test/access/data.mdb"); 
CryptCodecProvider cryptProvider = new CryptCodecProvider();
cryptProvider.setPassword("mypassword");
DatabaseBuilder dbb = new DatabaseBuilder(fi);
dbb.setFileFormat(Database.FileFormat.V1997);
dbb.setAutoSync(false);
dbb.setCodecProvider(cryptProvider);
dbb.setReadOnly(true);
Database dbc = dbb.open();

最后一行调用错误,这里是堆栈跟踪:

Exception in thread "main" java.lang.NoSuchMethodError: org.bouncycastle.crypto.StreamCipher.processBytes([BII[BI)V
at com.healthmarketscience.jackcess.impl.BaseCryptCodecHandler.streamDecrypt(BaseCryptCodecHandler.java:91)
at com.healthmarketscience.jackcess.impl.BaseJetCryptCodecHandler.decodePage(BaseJetCryptCodecHandler.java:62)
at com.healthmarketscience.jackcess.impl.PageChannel.readPage(PageChannel.java:224)
at com.healthmarketscience.jackcess.impl.UsageMap.read(UsageMap.java:130)
at com.healthmarketscience.jackcess.impl.PageChannel.initialize(PageChannel.java:117)
at com.healthmarketscience.jackcess.impl.DatabaseImpl.<init>(DatabaseImpl.java:516)
at com.healthmarketscience.jackcess.impl.DatabaseImpl.open(DatabaseImpl.java:389)
at com.healthmarketscience.jackcess.DatabaseBuilder.open(DatabaseBuilder.java:248)
at ACCESS.ACCESSTest.main(ACCESSTest.java:84)

最佳答案

事实证明,虽然 jackcess-encrypt source 与 bouncycaSTLe 1.52 兼容,但它不是 binary 兼容的。看这个feature request更多细节。基本上(目前),您需要使用 1.50 或更低版本的 bouncycaSTLe。

更新:从 jackcess-encrypt 的 2.1.1 版本开始,旧版(1.52 之前)和新版(1.52+)的 bouncycaSTLe 都应该可以正常工作。

关于java - 使用 Java/Jackcess 从加密的 Access .mdb 中读取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32664910/

相关文章:

Android,选择密码套件

java - 混合加密方法失败

java - 从 Web 应用程序访问 MS Access DB

Java 在运行相同的查询时从 SQL 返回不同的结果

java - 有没有办法阻止客户端从实例调用静态方法?

java - 如何为 Google Cloud SQL 配置 Java Hibernate?

java - 获取KeyStore实例时NPE

Java斐波那契堆栈溢出错误

java - Apache Thrift 中的对称加密 (AES)

java - UcanaccessSQLException: UCAExc:::3.0.1 表达式的数据类型不是 boolean 值