Настройка файла pkcs11 cfg - PullRequest
       13

Настройка файла pkcs11 cfg

1 голос
/ 20 июня 2019

Я пытаюсь запустить пример использования pkcs11, используя следующий код

import java.lang.reflect.Constructor;
import java.security.KeyStore;
import java.security.Provider;
import java.security.Security;
import java.util.Enumeration;

public class SignWithPKCS11
{
    public static void main (String [] args)
    {
            try
            {
                    Class<?> pkcs11Class = Class.forName("sun.security.pkcs11.SunPKCS11");
                    Constructor<?> construct = pkcs11Class.getConstructor(new Class[] {String.class});

                    String configName = "pkcs11.cfg";
                    Provider p = (Provider)construct.newInstance(new Object[] {configName});
                    Security.addProvider(p);
            }
            catch (Throwable t)
            {
                    t.printStackTrace();
            }

    }
}

Приведенный выше код вызывает файл pkcs11.cfg. Содержание этого

name = JSignPdf
library = /home/grados-sanchez/grive/E-CONNECTING/david/opensc-pkcs11.so

с помощью этой команды

java -cp . SignWithPKCS11
java -Djava.library.path=".:/home/grados-sanchez/grive/E-CONNECTING/david" -cp . SignWithPKCS11

но я получаю

java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at SignWithPKCS11.main(SignWithPKCS11.java:32)
Caused by: java.security.ProviderException: Initialization failed
    at sun.security.pkcs11.SunPKCS11.<init>(SunPKCS11.java:376)
    at sun.security.pkcs11.SunPKCS11.<init>(SunPKCS11.java:103)
Caused by: java.io.IOException: libopensc.so.6: cannot open shared object file: No such file or directory/home/grados-sanchez/grive/E-CONNECTING/david/opensc-pkcs11.so

Не могли бы вы помочь мне исправить это, пожалуйста? Что не так?

ПРИМЕЧАНИЕ. Когда я это сделал:

 ls -l /home/grados-sanchez/grive/E-CONNECTING/david/opensc-pkcs11.so

Я получаю

 -rw-rw-r-- 1 user user 220232 Jun 19 01:59 /home/grados-sanchez/grive/E-CONNECTING/david/opensc-pkcs11.so
...