0

我在 EJB2.0 上发布了另一个问题。我认为我之前的问题不会得到任何答案,因为 EJB2.0 是非常过时的技术,没有人愿意再研究它了。但是我的第一个问题得到了回答,我又试了一次运气。

我创建了一个简单的 EJB 2.x 实体 bean。我的实体 bean 使用另一个类 (UniqueIdGenerator) 为持久主键字段生成主键值。UniqueIdGenerator 使用 log4j 和 JDBC 连接,因此我为我的 EJB 项目配置了适当的构建路径引用。

在 EJB 项目 log4j-1.2.16.jar db2jcc.jar db2jcc_license_cu.jar 的构建路径中添加了以下 JARS

然后我将持久字段映射到数据库表字段。使用 RSA 中的 Prepare for Deployment 选项生成的代码(在 WAS 上部署)。

创建 EAR 项目并使用 Project References 选项将 EJB 项目 (HMS) 添加到 EAR 项目。

我没有设置任何其他路径/类路径。

启动 WAS,在 WAS 上部署 EAR 并启动 Universal Test Client 来测试实体 bean。使用远程接口,我尝试创建我的第一个 bean,输入字段的值并单击通用测试客户端上的提交。在服务器端,它调用实体 bean 的 ejbCreate(),但在加载 UniqueIdGenerator 类时失败,错误为 NoClassDefFoundError

这是堆栈跟踪

java.rmi.ServerException: RemoteException occurred in server thread; nested exception is: 
    com.ibm.ejs.container.CreateFailureException: ; nested exception is: 
    java.lang.NoClassDefFoundError: org.apache.log4j.LogManager
    at com.ibm.CORBA.iiop.UtilDelegateImpl.mapSystemException(UtilDelegateImpl.java:235)
    at com.ibm.CORBA.iiop.UtilDelegateImpl.wrapException(UtilDelegateImpl.java:743)
    at javax.rmi.CORBA.Util.wrapException(Util.java:296)
    at ejbs._EJSRemoteCMPAddressHome_824957aa_Stub.create(_EJSRemoteCMPAddressHome_824957aa_Stub.java:258)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at com.ibm.etools.utc.model.ReflectionMethodModel.invoke(ReflectionMethodModel.java:65)
    at com.ibm.etools.utc.servlet.InvokeServlet.invoke(InvokeServlet.java:113)
    at com.ibm.etools.utc.servlet.InvokeServlet.doPost(InvokeServlet.java:374)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:738)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:831)
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1657)
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:939)
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:502)
    at com.ibm.ws.webcontainer.servlet.ServletWrapperImpl.handleRequest(ServletWrapperImpl.java:179)
    at com.ibm.ws.webcontainer.servlet.CacheServletWrapper.handleRequest(CacheServletWrapper.java:91)
    at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:864)
    at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1583)
    at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:186)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:452)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest(HttpInboundLink.java:511)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest(HttpInboundLink.java:305)
    at com.ibm.ws.http.channel.inbound.impl.HttpICLReadCallback.complete(HttpICLReadCallback.java:83)
    at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:165)
    at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)
    at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)
    at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:138)
    at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:204)
    at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:775)
    at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:905)
    at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1604)
Caused by: com.ibm.ejs.container.CreateFailureException: ; nested exception is: 
    java.lang.NoClassDefFoundError: org.apache.log4j.LogManager
    at ejbs.EJSCMPAddressHomeBean_824957aa.create(EJSCMPAddressHomeBean_824957aa.java:47)
    at ejbs.EJSRemoteCMPAddressHome_824957aa.create(EJSRemoteCMPAddressHome_824957aa.java:28)
    at ejbs._EJSRemoteCMPAddressHome_824957aa_Stub.create(_EJSRemoteCMPAddressHome_824957aa_Stub.java:251)
    ... 29 more
Caused by: java.lang.NoClassDefFoundError: org.apache.log4j.LogManager
    at utils.UniqueLongIdGenerator.(UniqueLongIdGenerator.java:40)
    at java.lang.J9VMInternals.initializeImpl(Native Method)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:200)
    at utils.UniqueIdGenerator.(UniqueIdGenerator.java:28)
    at utils.UniqueIdGenerator.(UniqueIdGenerator.java:24)
    at java.lang.J9VMInternals.initializeImpl(Native Method)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:200)
    at ejbs.AddressBean.ejbCreate(AddressBean.java:46)
    at ejbs.ConcreteAddress_824957aa.ejbCreate(ConcreteAddress_824957aa.java:122)
    at ejbs.EJSCMPAddressHomeBean_824957aa.create(EJSCMPAddressHomeBean_824957aa.java:33)
    ... 31 more
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.LogManager
    at java.net.URLClassLoader.findClass(URLClassLoader.java:434)
    at com.ibm.ws.bootstrap.ExtClassLoader.findClass(ExtClassLoader.java:191)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:660)
    at com.ibm.ws.bootstrap.ExtClassLoader.loadClass(ExtClassLoader.java:111)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:626)
    at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:62)
    at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:58)
    at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:509)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:626)
    ... 41 more

我是否错过了配置中的任何内容。我是否需要在 EAR 项目中的某处添加所有 jar 文件。将它们设置在 EJB 项目的构建路径中还不够吗?

4

1 回答 1

1

我在以下链接中找到了答案

如何在 ejb-jar 中包含外部 jar

Developerworks 文章 http://www.ibm.com/developerworks/rational/library/07/1211_schrag/index.html

您需要将第三方 jar 导入到您的 EAR 项目中,然后在您的 EJB 项目的 MANIFEST.MF 文件中设置 JAR 依赖项。将外部 jar 导入 EAR 项目后,它们将在 MANIFEST.MF 的资源管理器中可用

于 2013-06-07T07:27:34.737 回答