简体   繁体   English

无法使本机库(.so)在Grails 3中执行

[英]Unable to get a native library (.so) to execute in grails 3

I'm using a native library in my java code which is working perfectly through and through. 我在我的Java代码中使用了一个本机库,该库始终运行良好。 When I use the same library in grails 3 application, it gets loaded fine, but when I call a native method, it throws UnsatisfiedLinkError exception. 当我在grails 3应用程序中使用相同的库时,它可以很好地加载,但是当我调用本机方法时,它将引发UnsatisfiedLinkError异常。

I'm using following code in both cases: 在两种情况下,我都使用以下代码:

try{
    System.loadLibrary("TrippleDes")
    String plainText = "passw0rd.!";
    String cipher = JniWrapper.encrypt(plainText);

    String orgStr = JniWrapper.decrypt(cipher);
    System.out.println("Original text: " + plainText);
    System.out.println("Cipher text: " + cipher);
    System.out.println("Restored text: " + orgStr);
}catch (Exception ex){
    System.out.println(ex.getMessage());
}

For simple java code, it works fine with the relevant output. 对于简单的Java代码,它可以与相关输出一起正常工作。 For same code in grails, it throws following exception. 对于grails中的相同代码,它将引发以下异常。 I tried to call the native function directly from groovy class as well as wrapping it up in a java class but to no avail. 我试图直接从groovy类中调用本机函数,并将其包装在java类中,但无济于事。 Stacktrace doesn't unveil any substantial debugging probes, but for completeness, here goes: Stacktrace没有公开任何实质性的调试探针,但是为了完整起见,这里有:

java.lang.UnsatisfiedLinkError: com.ef.apps.licensing.JniWrapper.encrypt(Ljava/lang/String;)Ljava/lang/String;
    at com.ef.apps.licensing.JniWrapper.encrypt(Native Method)
    at com.ef.apps.licensing.licCheck.check(licCheck.java:7)
    at com.ef.apps.licensing.licCheck$check.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:117)
    at umm1.BootStrap$_closure1.doCall(BootStrap.groovy:14)
    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)
    at org.springsource.loaded.ri.ReflectiveInterceptor.jlrMethodInvoke(ReflectiveInterceptor.java:1426)
    at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:93)
    at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:325)
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1215)
    at groovy.lang.ExpandoMetaClass.invokeMethod(ExpandoMetaClass.java:1125)
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1024)
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1089)
    at groovy.lang.ExpandoMetaClass.invokeMethod(ExpandoMetaClass.java:1125)
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1024)
    at groovy.lang.Closure.call(Closure.java:414)
    at groovy.lang.Closure.call(Closure.java:408)
    at grails.util.Environment.evaluateEnvironmentSpecificBlock(Environment.java:516)
    at grails.util.Environment.executeForEnvironment(Environment.java:509)
    at grails.util.Environment.executeForCurrentEnvironment(Environment.java:485)
    at org.grails.web.servlet.boostrap.DefaultGrailsBootstrapClass.callInit(DefaultGrailsBootstrapClass.java:62)
    at org.grails.web.servlet.context.GrailsConfigUtils.executeGrailsBootstraps(GrailsConfigUtils.java:65)
    at org.grails.plugins.web.servlet.context.BootStrapClassRunner.onStartup(BootStrapClassRunner.groovy:53)
    at grails.boot.config.GrailsApplicationPostProcessor.onApplicationEvent(GrailsApplicationPostProcessor.groovy:256)
    at grails.boot.config.GrailsApplicationPostProcessor.onApplicationEvent(GrailsApplicationPostProcessor.groovy)
    at org.springframework.context.event.SimpleApplicationEventMulticaster.invokeListener(SimpleApplicationEventMulticaster.java:166)
    at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:138)
    at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:382)
    at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:336)
    at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:877)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.finishRefresh(EmbeddedWebApplicationContext.java:144)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:544)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:761)
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:371)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:315)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:79)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:381)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:370)
    at grails.boot.GrailsApp$run.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:133)
    at umm1.Application.main(Application.groovy:8)

What am I missing here? 我在这里想念什么?

Operating System : Ubuntu 16.04 with Linux 4.4.0-104-generic #127-Ubuntu x86_64 x86_64 x86_64 GNU/Linux 操作系统 :Ubuntu 16.04 with Linux 4.4.0-104-generic#127-Ubuntu x86_64 x86_64 x86_64 GNU / Linux

Grails Version : 3.2.2 Grails版本 :3.2.2

JDK Version : JDK版本

  • openjdk version "1.8.0_151" openjdk版本“ 1.8.0_151”
  • OpenJDK Runtime Environment (build 1.8.0_151-8u151-b12-0ubuntu0.16.04.2-b12) OpenJDK运行时环境(内部版本1.8.0_151-8u151-b12-0ubuntu0.16.04.2-b12)
  • OpenJDK 64-Bit Server VM (build 25.151-b12, mixed mode) OpenJDK 64位服务器VM(内部版本25.151-b12,混合模式)

Groovy uses different class loader than java. Groovy使用与Java不同的类加载器。 You'll have to workout in following direction: 1. When you load library, explicitly tell which loader to use. 您必须朝以下方向进行锻炼:1.加载库时,明确告诉要使用的加载器。 2. Fork JVM in Grails so that it uses loader which has path to that library set. 2.在Grails中使用Fork JVM,以便它使用具有该库集路径的加载器。

Here is similar problem foe Grails2 UnsatisfiedLinkError when using a JNI native library from Grails application 从Grails应用程序使用JNI本机库时,这是Grails2 UnsatisfiedLinkError的类似问题

I'd love to know which path you took and how do you resolve in Grails3. 我很想知道您在Grails3中走了哪条路以及如何解决。

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

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