背景
在新装的win系统下,java项目人脸识别项目要调用动态库,下面就说说问题
问题
Exception in thread “main” java.lang.UnsatisfiedLinkError: Unable to load library ‘C:\xxx\xxx\xxx\xxx.dll’: Native library (win32-x86-64/C:\xxx\xxx\xxx\xxx.dll) not found in resource path
我是拷贝git issues上的,因为当时我没记录这些错误。这错误大概就长这样,花费了我一天半时间。
在这个过程也了解了很多java jna的知识。
当时的分析
当时就觉得路径不对导致加载不到dll,所以通过jna.class.path
,设置动态库的环境路径来加载,以及使用开启jna调试模式看日志。但是最终还是不行,我尝试过配置环境变量、开启jna调试、升级jna版本为5.4.0、断点调试、在调试的时候我都怀疑是不是Native.load是不是对win路径的写法有特殊要求。都不行!还有jre运行与系统位数不对等解决方法。
但是现象很奇怪的我的有个idea项目是可以运行的,独立打包出来就不行,我就开始怀疑java启动参数、环境变量是不是有问题。但是最终所有办法都试了就是不行。
最后在我无意的时候,在github的issues上看到了类似的问题。
https://github.com/java-native-access/jna/issues/725
里面有个国外小哥说