2011-05-06 76 views
8

Iam尝试将字符串消息发送到在weblogic服务器中创建的JMS队列中。 IAM使用Eclipse IDE和运行我的Web应用程序,我得到下面的错误和Tomcat服务器获取shutdown.The错误无法将消息发送到weblogic队列

javax.naming.CommunicationException [Root exception is java.rmi.UnmarshalException: failed to unmarshal class weblogic.security.acl.internal.AuthenticatedUser; nested exception is: 
    java.io.StreamCorruptedException: invalid type code: 31] 
    at weblogic.jndi.internal.ExceptionTranslator.toNamingException(ExceptionTranslator.java:74) 
    at weblogic.jndi.internal.ExceptionTranslator.toNamingException(ExceptionTranslator.java:32) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.toNamingException(WLInitialContextFactoryDelegate.java:773) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.pushSubject(WLInitialContextFactoryDelegate.java:673) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.newContext(WLInitialContextFactoryDelegate.java:466) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.getInitialContext(WLInitialContextFactoryDelegate.java:373) 
    at weblogic.jndi.Environment.getContext(Environment.java:307) 
    at weblogic.jndi.Environment.getContext(Environment.java:277) 
    at weblogic.jndi.WLInitialContextFactory.getInitialContext(WLInitialContextFactory.java:117) 
    at javax.naming.spi.NamingManager.getInitialContext(Unknown Source) 
    at javax.naming.InitialContext.getDefaultInitCtx(Unknown Source) 
    at javax.naming.InitialContext.init(Unknown Source) 
    at javax.naming.InitialContext.<init>(Unknown Source) 
    at com.infotech.jms.JMSBEAQueueSend.sendMessage(JMSBEAQueueSend.java:48) 
    at com.infotech.struts.actions.AppAction.execute(AppAction.java:75) 
    at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:431) 
    at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236) 
    at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196) 
    at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588) 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) 
    at java.lang.Thread.run(Unknown Source) 
Caused by: java.rmi.UnmarshalException: failed to unmarshal class weblogic.security.acl.internal.AuthenticatedUser; nested exception is: 
    java.io.StreamCorruptedException: invalid type code: 31 
    at weblogic.rjvm.ResponseImpl.unmarshalReturn(ResponseImpl.java:229) 
    at weblogic.rmi.internal.BasicRemoteRef.invoke(BasicRemoteRef.java:224) 
    at weblogic.common.internal.RMIBootServiceImpl_1001_WLStub.authenticate(Unknown Source) 
    at weblogic.security.acl.internal.Security$1.run(Security.java:185) 
    at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:363) 
    at weblogic.security.service.SecurityManager.runAs(Unknown Source) 
    at weblogic.security.acl.internal.Security.authenticate(Security.java:181) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.authenticateRemotely(WLInitialContextFactoryDelegate.java:734) 
    at weblogic.jndi.WLInitialContextFactoryDelegate.pushSubject(WLInitialContextFactoryDelegate.java:667) 
    ... 29 more 
Caused by: java.io.StreamCorruptedException: invalid type code: 31 
    at java.io.ObjectInputStream.readObject0(Unknown Source) 
    at java.io.ObjectInputStream.readObject(Unknown Source) 
    at weblogic.utils.io.ChunkedObjectInputStream.readObject(ChunkedObjectInputStream.java:195) 
    at weblogic.rjvm.MsgAbbrevInputStream.readObject(MsgAbbrevInputStream.java:565) 
    at weblogic.utils.io.ChunkedObjectInputStream.readObject(ChunkedObjectInputStream.java:191) 
    at weblogic.rmi.internal.ObjectIO.readObject(ObjectIO.java:62) 
    at weblogic.rjvm.ResponseImpl.unmarshalReturn(ResponseImpl.java:227) 
    ... 37 more 

请帮我out.Thanks以及基于一些问候

+0

请问是否需要进一步的信息.. – TechnocraT 2011-05-06 11:55:19

回答

14

快速研究这个问题,它似乎是由应用服务器和客户端之间使用不同的JDK级别引起的。我已经看到的大多数示例都显示了在Java 5上运行Weblogic时在客户端上使用Java 6时发生的情况。

虽然我没有亲自尝试过,但建议将以下内容添加到客户端应用程序的启动命令:

-Dsun.lang.ClassLoader.allowArraySyntax=true 

设置此属性可在ClassLoader的loadClass方法中启用向后兼容模式。

这是一个link to an Oracle forum question,它提供了一些额外的信息。

或者,如果您正在执行直接集成,则必须查看确保客户端和服务器运行相同的JVM级别。显然,这通常不是最佳解决方案。

+0

我使用eclipse ide ..我需要在哪里添加启动注释? – TechnocraT 2011-05-09 05:01:50

+1

如果您正在Eclipse中运行您的客户端,那么您需要将此命令添加到客户端的运行配置中:右键单击项目,然后转到“Run As-> Run Configurations”。选择你的客户端的运行配置应该在'Java Application'下。选择'arguments'选项卡并在'VM Arguments'文本框中输入testin。这将允许客户端使用'sun.lang.ClassLoader.allowArraySyntax'系统属性设置为'true'来运行。如果您从命令行运行应用程序,请在执行应用程序之前添加-D ...文本,例如,java -D ... Main。 – 2011-05-09 17:50:25

+0

最后解决了它,问题出在默认情况下使用jdk 1.6,我改为1.5,它的工作。谢谢你的帮助。 – TechnocraT 2011-05-20 11:40:11