Java工作笔记:部署Tomcat时使用jni和jna调用DLL文件的问题

部署Tomcat时使用jni和jna调用DLL文件的问题

我的前一篇博客提到,我们公司项目的restful框架中要用到底层的DLL C++库,最后经过测试验证结果选择采用JNA方法来调DLL库。之后基础框架在IDEA中的jetty服务中调试成功,但是在部署到Tomcat上时出现了无法加载DLL库的状况,只能现学现卖了。


一.        DLL文件放在Tomcat下的方法:

这一部分摘自:http://blog.csdn.net/wjgnuc/article/details/16876329

Tomcat中加载dll,供其它接口调用:

Tomcat目录根下新建一个文件夹,这里就叫DLL吧,<tomcat_home>/DLL

把需要用到的dll放入新建的DLL目录下;

编辑<tomcat_home>/conf/catalina.properties,在common.loader后面追加${catalina.home}/DLL

编辑<tomcat_home>/bin/目录下的catalina.bat,在rem Copy CATALINA_BASE from CATALINA_HOME if not  defined的段落中增加如下语句:

set LD_LIBRARY_PATH=%CATALINA_BASE%\DLL

set JAVA_OPTS=-Djava.library.path=%CATALINA_BASE%\DLL%JAVA_OPTS%

保存重新启动Tomcatdeploy war即可。

(在此感谢这位博主给了我很多启发)


DLL文件放在java.library.path路径下,可以通过System.out.println(System.getProperty("java.library.path"));语句查看都有哪些系统调默认调用的文件路径。Tomcat会在这些目录下寻找要加载的文件、库等。


在使用JNA调用DLL时,总是提示无法加载相应的库。把DLL文件放在各种路径下都不起作用。无奈之下,我换成JNI工具尝试了一下,结果提示Can't load IA 32-bit .dll on a AMD 64-bit platform。真相终于浮出了水面,原来是因为JDKDLL系统不兼容(万万没想到问题出在这里),于是我把DLL重新编译成64位试了一下,成功部署。然后我又换成JNA工具后试了一下也成功部署(早该换成JNI试一下,就是因为JNI使用步骤过于繁琐,所以一直对JNA不死心,结果拖了很长时间),问题解决。


四.使用JNA的时候,大多数网上教程中Native.loadLibrary(“DLL name”, classname.class); 中的第一个参数都是相对路径。按照编程经验,这里应该也可以写成绝对路径,例如:

Native.loadLibrary(“C:\Program Files (x86)\Java\jdk1.8.0_51\bin\ DLLname.dll”, classname.class);

我这样试着跑了一下,证明我的猜想是正确的。


五. 把DLL放在Tomcat文件夹下的bin文件中也可以找到。Linux下放在 /user/local/bin 中。这是我最后采用的方式。


总结:问题可能出在方方面面,需要学习的还很多,经验也相当重要。同时应该在自己的代码中建立完整的异常报错体系,和良好的异常处理习惯。但是我又担心太多的分支处理会影响整体的性能。还是好好修炼内功才是王道啊。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值