繁体   English   中英

如何在小程序中使用 MSCAPI 来加载密钥库

[英]How can I use MSCAPI inside an applet to load a keystore

我有一个小程序,允许用户使用他们的个人证书签署文档。 小程序已签名,但当它尝试加载其密钥库时,我收到与 sunMSCAPI 相关的访问被拒绝错误。 这是由以下代码行引起的:

store = KeyStore.getInstance("Windows-MY");
store.load(null, null);

根据我对小程序签名的了解,在我需要跳过的签名过程之后没有其他步骤(编辑策略文件等)。 我尝试将所有小程序功能包装在:

AccessController.doPrivileged(new PrivilegedAction() {
  public Object run() {
    etc...

但这没有帮助。 我已经在各个论坛上找到了一些评论,认为 sunMSCAPI 仅在 JDK 6 中可用......我已经得到了。 我的想法不多了,任何帮助将不胜感激。

对于潜在的帮助,这里是拒绝访问错误的堆栈跟踪:

java.security.AccessControlException: access denied (java.security.SecurityPermission authProvider.SunMSCAPI)
    at java.security.AccessControlContext.checkPermission(Unknown Source)
    at java.security.AccessController.checkPermission(Unknown Source)
    at java.lang.SecurityManager.checkPermission(Unknown Source)
    at sun.security.mscapi.KeyStore.engineLoad(KeyStore.java:736)
    at sun.security.mscapi.KeyStore$MY.engineLoad(KeyStore.java:43)
    at java.security.KeyStore.load(Unknown Source)
    at com.bloop.signature.PKCS11.loadKeyStore(PKCS11.java:42)
    at com.bloop.signature.PKCS11.sign(PKCS11.java:29)
    at com.bloop.signature.applet.SignApplet.signDocument(SignApplet.java:103)
    at com.bloop.signature.applet.SignApplet.access$200(SignApplet.java:19)
    at com.bloop.signature.applet.SignApplet$1.run(SignApplet.java:64)
    at java.lang.Thread.run(Unknown Source)

似乎我用来签署小程序的密钥库不知何故无效。 我生成了一个新的,用它签名,清除了 java 缓存,一切都开始运行良好。

为了完整起见,这是我运行以生成新商店的命令:

keytool -genkey -alias keyPair -keyalg RSA -validity 500 -keystore myKeyStore -keypass <password> -storepass <password> -dname "<CN,OU,O,L,ST,C details>"

如果其他人遇到此问题,希望以上内容有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM