Mig*_*res 5 macos smartcard jsvc
我有一个需要在MacOS Sierra中作为守护进程运行的JAR文件,我决定使用Apache Commons Daemon和JSVC来达到这个目的.我知道也许JSVC并不是真的需要用于此目的(它似乎只允许在低范围内打开端口)并且可以通过系统/启动实现相同的功能,因此任何有或没有JSVC的帮助/解决方案都是值得赞赏的.
这就是我从命令行运行jar的方法,它运行正常.它使用端口8085打开WebSocket连接,并等待传入连接.然后,它连接到智能卡读卡器并从卡中获取一些数据.
java -cp "myjar.jar:jars/*" full_class_name
Run Code Online (Sandbox Code Playgroud)
现在,当我尝试使用Apache Commons Daemon接口和JSVC运行相同的jar时,jar正常启动并开始在端口8085中侦听.
./jsvc -debug -cp commons-daemon-1.1.0.jar:myjar.jar:jars/* -cwd . -pidfile /tmp/file.pid full_class_name
Run Code Online (Sandbox Code Playgroud)
问题是,出于某种原因,尝试连接智能卡读卡器时会出现异常.
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)
Run Code Online (Sandbox Code Playgroud)
使用java -jar运行jar时工作正常的事实让我相信问题与配置有关.有关使用JSVC无法提供服务的任何想法?
提前致谢.
| 归档时间: |
|
| 查看次数: |
190 次 |
| 最近记录: |