
本文旨在解决在 Oracle 数据库中执行 Java 存储过程时,遇到的 `java.security.KeyStoreException: PKCS11 not found` 异常。通过分析异常原因,并提供配置 Java 安全属性以及排查 Oracle Job 相关问题的方案,帮助开发者成功在 Oracle 环境中调用涉及 USB Token 证书读取的 Java 代码。
当 Java 代码尝试使用 KeyStore.getInstance("PKCS11") 获取 PKCS11 类型的 KeyStore 时,如果 Java 运行时环境 (JRE) 未正确配置 PKCS11 提供程序,就会抛出 java.security.KeyStoreException: PKCS11 not found 异常。这通常发生在以下情况:
解决此问题的关键在于确保 Oracle 数据库使用的 JRE 正确配置了 PKCS11 提供程序。以下是一些可能的解决方案:
找到 Oracle 数据库使用的 JRE 的 java.security 文件。该文件通常位于 $ORACLE_HOME/javavm/lib/security 目录下。
立即学习“Java免费学习笔记(深入)”;
编辑 java.security 文件,添加或修改以下行:
security.provider.13=SunPKCS11 config_file.cfg
config_file.cfg 文件示例:
name = SmartCard library = /path/to/your/pkcs11/library.so # 替换为你的 PKCS11 库的实际路径 slotListIndex = 0 # 替换为你的 Token 所在的 Slot 索引
注意事项:
修改 java.security 文件后,需要重启 Oracle 数据库才能使更改生效。
除了修改 java.security 文件外,还可以在 Java 代码中动态添加 PKCS11 提供程序:
import java.security.Provider;
import java.security.Security;
public class GetSignatureNew {
public static void main(String args[]) {
GetSignatureNew sdk = new GetSignatureNew();
}
public static String GetSignatureFun(String serialized) {
String pwd = "*******";
char[] pin = new char[pwd.length()];
try {
for (int i = 0; i < pwd.length(); i++) {
pin[i] = pwd.charAt(i);
}
// 动态添加 PKCS11 提供程序
Provider p = new sun.security.pkcs11.SunPKCS11("config_file.cfg"); // 替换为你的配置文件路径
Security.addProvider(p);
// Get Certificate and private key from token
KeyStore ks = KeyStore.getInstance("PKCS11");
ks.load(null, pin);
Enumeration enu = ks.aliases();
String alias = String.valueOf(enu.nextElement());
X509Certificate cert = (X509Certificate) ks.getCertificate(alias);
PrivateKey pk = (PrivateKey) ks.getKey(alias, pin);
byte[] output = cert.getEncoded();
String b64 = Base64.getEncoder().encodeToString(output);
return b64;
} catch (Exception e) {
e.printStackTrace();
return e.toString();
}
}
}注意事项:
如果使用 Oracle Job 调度 Java 代码,需要检查以下问题:
可以使用以下 SQL 查询来查看 Oracle Job 的错误信息:
SELECT log_date, status, error# , output FROM user_scheduler_job_run_details WHERE job_name = 'YOUR_JOB_NAME' -- 替换为你的 Job 名称 ORDER BY log_date DESC;
确保 Oracle 数据库使用的 Java 版本与开发环境一致,并且支持 PKCS11 提供程序。
使用供应商提供的工具或示例代码验证 PKCS11 库是否正常工作。这可以帮助确定问题是否出在 PKCS11 库本身。
解决 java.security.KeyStoreException: PKCS11 not found 异常需要仔细检查 Java 安全属性配置、PKCS11 库路径、权限设置以及 Oracle Job 相关配置。通过逐步排查这些问题,最终可以成功在 Oracle 数据库中执行涉及 USB Token 证书读取的 Java 代码。建议在修改任何配置之前备份相关文件,以便在出现问题时可以恢复。
以上就是解决 Oracle 数据库执行 Java 存储过程时 PKCS11 异常的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号