我正在尝试在 Play 2.4.x 应用程序中加载本机库。我编写了一个简单的测试,该测试在 IDE (IntelliJ) 和 SBT 中都运行良好。在这两种情况下我都设置java.library.path
让测试运行。
我在IDE中设置-Djava.library.path=$USER_HOME$/dev/lindoapi/bin/linux64
在测试运行配置中。
根据 sbt 文档,我的build.sbt
正在分叉 JVM 并设置java.library.path
.
javaOptions += "-Djava.library.path=/home/aczerwon/dev/lindoapi/bin/linux64"
fork := true
以下测试在 IDE 和 from 中都顺利通过activator test
.
class LindoApiSpec extends Specification {
System.loadLibrary("lindojni")
"The Lindo API" should {
"have a valid license" in {
val lindo = new LindoEnvironment()
lindo.apiVerion() must beSuccessfulTry.withValue("LINDO API Version 9.0.2120.225")
}
}
当在测试上下文之外时,我会在 Play 的启动生命周期中加载本机库。
object Global extends GlobalSettings {
override def beforeStart(app: Application) = {
System.loadLibrary("lindojni")
}
}
当我从 webapi 调用相同的方法时(activator ~run
),我得到一个UnsatisfiedLinkError
error.
1) Error injecting constructor, java.lang.UnsatisfiedLinkError: no lindojni in java.library.path
at play.api.GlobalPlugin.<init>(GlobalSettings.scala:262)
at play.api.GlobalPlugin.class(GlobalSettings.scala:262)
while locating play.api.GlobalPlugin
网络 API 如下所示:
class OptimizationApi extends Controller {
def version() = Action {
val lindo = new LindoEnvironment()
lindo.apiVerion() match {
case Success(version) => Ok(version)
case Failure(e) => BadRequest(e.getMessage)
}
}
}
我假设我的 build.sbt 会分叉 JVM 并设置java.library.path
for both test
and run
上下文。关于我做错了什么的任何线索吗?
新的信息
当我开始时activator -Djava.library.path=$USER_HOME$/dev/lindoapi/bin/linux64
或设置 JAVA_OPTS,调用System.loadLibrary(...)
在启动生命周期中。我仍然得到UnsatisfiedLinkError
,但稍后当我通过 JNI 调用本机库时会发生这种情况。很奇怪。