MacOS和JSVC:SCARD_E_NO_服务:智能卡资源管理器未运行

MacOS和JSVC:SCARD_E_NO_服务:智能卡资源管理器未运行,macos,smartcard,jsvc,Macos,Smartcard,Jsvc,我在MacOS Sierra中得到了一个需要作为守护进程运行的JAR文件,为此我决定使用Apache Commons守护进程和JSVC。我知道,也许JSVC并不是真正需要的(它似乎只允许在较低范围内打开端口),并且可以通过system/launch实现同样的目的,因此无论是否使用JSVC,任何帮助/解决方案都是值得赞赏的 这就是我从命令行运行jar的方式,它可以正常工作。它使用端口8085打开WebSocket连接并等待传入连接。然后,它连接到智能卡读卡器并从卡中获取一些数据 java -cp

我在MacOS Sierra中得到了一个需要作为守护进程运行的JAR文件,为此我决定使用Apache Commons守护进程和JSVC。我知道,也许JSVC并不是真正需要的(它似乎只允许在较低范围内打开端口),并且可以通过system/launch实现同样的目的,因此无论是否使用JSVC,任何帮助/解决方案都是值得赞赏的

这就是我从命令行运行jar的方式,它可以正常工作。它使用端口8085打开WebSocket连接并等待传入连接。然后,它连接到智能卡读卡器并从卡中获取一些数据

java -cp "myjar.jar:jars/*" full_class_name
现在,当我尝试使用ApacheCommons守护程序接口和JSVC运行同一个jar时,jar会正确启动,并在端口8085中开始侦听

./jsvc -debug -cp commons-daemon-1.1.0.jar:myjar.jar:jars/* -cwd . -pidfile /tmp/file.pid full_class_name
问题是,出于某种原因,尝试连接到智能卡读卡器时出现异常

INFORMACIÓN: WebSocket Registered apps: URLs all start with ws://localhost:8085
may 15, 2018 10:04:37 AM org.glassfish.tyrus.server.Server start
INFORMACIÓN: WebSocket server started.
LISTENING
Daemon started successfully
java_start done
Waiting for a signal to be delivered
create_tmp_file: /tmp/541.jsvc_up
jnasmartcardio.Smartcardio$EstablishContextException: jnasmartcardio.Smartcardio$JnaPCSCException: SCardEstablishContext got response 0x8010001d (SCARD_E_NO_SERVICE: The Smart card resource manager is not running.)
    at jnasmartcardio.Smartcardio$JnaTerminalFactorySpi.engineTerminals(Smartcardio.java:81)
    at javax.smartcardio.TerminalFactory.terminals(TerminalFactory.java:351)
    at apdu4j.TerminalManager.getTheReader(TerminalManager.java:228)
    at com.st.middleware.a.a.b.connect(SourceFile:24)
    at com.st.middleware.a.b.connect(SourceFile:18)
    at com.st.middleware.a.b.getCertificates(SourceFile:1024)
    at com.st.middleware.MiddlewareImpl.a(SourceFile:113)
    at com.st.middleware.MiddlewareImpl.getAuthCertificates(SourceFile:151)
    at com.st.communication.card.websocket.a.handleMessage(SourceFile:79)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
jar在使用java-jar运行时工作正常这一事实让我相信问题在于配置。关于为什么使用JSVC无法使用该服务,您有什么想法吗


提前感谢。

我在Linux下的jnasmartcardio也有同样的例外。我的解决方案是缺少一个本机库。我安装了pcscd,异常消失了