写一个jar文件实用程序

时间:2012-04-26 14:50:31

标签: java jar

我正在编写一个实用程序jar文件,以便共享到多个项目中。基本上它处理建立数据库连接并进行计算,然后返回值。其他项目将导入我的jar文件并调用我的函数。

现在我遇到问题,当我试图调用jar文件中的一个函数时。在eclipse中没有编译错误,但是当我在app服务器上测试它时收到此错误

22:16:35,177 DEBUG ExecutionContext:187 - Transitioning to lifecycle stage RequestComplete
22:16:35,178  WARN DefaultExceptionHandler:94 - Unhandled exception caught by the Stripes default exception handler.
net.sourceforge.stripes.exception.StripesServletException: ActionBean execution threw an exception.
    at net.sourceforge.stripes.controller.DispatcherServlet.service(DispatcherServlet.java:183)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at net.sourceforge.stripes.controller.StripesFilter.doFilter(StripesFilter.java:247)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:185)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:151)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:269)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)
Caused by: java.lang.NoClassDefFoundError: com/my/rnd/test/utils/SimplePing
    at com.app.action.JbpmProcessInstanceActionBean.testTrigger(JbpmProcessInstanceActionBean.java:83)
    at com.app.action.JbpmProcessInstanceActionBean.loadProcInstanceList(JbpmProcessInstanceActionBean.java:72)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)

我使用eclipse导出jar文件,这是SimplePing的示例函数

public class SimplePing {

     /**
      * @param args
      */
     public  void testSimplePing() {
        // TODO Auto-generated method stub
        System.out.println("This is a simple ping .");
     }

}

似乎appserver无法找到我的类,即使它存在于jar文件中。欢迎任何帮助

3 个答案:

答案 0 :(得分:1)

如果仔细查看错误堆栈,可以看到以下内容:

Caused by: java.lang.NoClassDefFoundError: com/my/rnd/test/utils/SimplePing

如果您有下列任一情况,这是一个常见错误:

  1. jar(s)
  2. 中缺少lib
  3. 您的jar(s)
  4. 缺少一些classpath
  5. 您的MANIFEST文件中缺少某些依赖项:

    ...
    Main-Class: fully.qualified.MainClass
    Class-Path: lib/dependency1-X.Y.jar lib/dependency2-W.Z.jar
    ...

  6. 您有JDK个问题

  7. 最终所有连接到同一个问题:丢失的jar(JDK或第三方相关的jar)
    您还可以使用maven插件进行eclipse,它可以管理您当前项目的依赖性以及您的项目所需的jar能力,如果您喜欢Maven的话。

答案 1 :(得分:0)

这是一个很好的问题

我有两种方法可以想到

  1. 尝试使用Maven (m2e plugin) - 这将为您管理依赖项  如果这样做,请记住将 Maven依赖项添加到项目部署程序集(右键单击 - 属性)

  2. 使用部署程序集并添加其他项目

答案 2 :(得分:0)

使用7-zip或winzip等程序打开jar,并验证您是否在其中看到此目录结构和文件:com / my / rnd / test / utils / SimplePing.class