gpt4 book ai didi

java - 编写 jar 文件实用程序

转载 作者:搜寻专家 更新时间:2023-11-01 03:42:51 24 4
gpt4 key购买 nike

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

现在我在尝试调用 jar 文件中的函数之一时遇到问题。在 eclipse 中没有编译错误但是当我在应用程序服务器上测试它时我收到这个错误

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 .");
}

}

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

最佳答案

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

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

当您遇到以下情况之一时,这是一个常见错误:

  1. 你有一个 jar(s)在你的 lib 中丢失
  2. 你有一些 jar(s)你的 classpath 不见了
  3. 您的 MANIFEST 中缺少一些依赖项文件:

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

  4. 你有一个 JDK问题

最终都连接到同一个问题:A missing jar (JDK or third-party related jar)
您还可以使用 eclipse 的 maven 插件,它将管理您当前项目和 jar 的依赖关系。如果您喜欢 Maven,当然可以使用您的项目所需的功能。

关于java - 编写 jar 文件实用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10335912/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com