4

問題の背景:

鉱山外の機関によって公開された Web サービス メソッドを使用します。Web サービスは JAX WS-SUN によって生成されました。外部委託者によって公開されたメソッドをカプセル化する私の機関の国内消費用の他の Web サービスを実装し、JAX WS-SUN (IBM ではありません) を使用します。当初、いくつかの jar の認識に問題がありました。クラスローダーPARENT_LASTでjarを使用するようにサーバー上の共有ライブラリを設定してみましたが、機能しませんでした。JAX WS-IBM ライブラリで reliza を試してみましたが、成功しなかったので、JAX WS-SUN (外部サービス プロバイダーが使用するライブラリ) で試してみてください。次に、「承認済み」フォルダーを使用して解決策を見つけました (このフォルダーは既に存在していましたが、空でした)。これは、WAS 7.0 に含まれる sdk ディレクトリ ツリーにあり、物理的に (私の PC 内に) ある "classes" フォルダーに他の jar をコピーします。

endorsed: E: \ IBM \ SDP \ jdk \ jre \ lib \ Endorsed
jar copied: 
- saaj-api.jar
- Saaj-impl.jar
- Serializer-2.7.1.jar
- Stax-1.2.0.jar
- Stax-ex.jar
- Streambuffer.jar
- Xalan-2.7.1.jar
- XercesImpl-2.9.0.jar
- Xml-apis-1.3.04.jar

classes: E: \ IBM \ SDP \ runtimes \ base_v7 \ profiles \ AppSrv01 \ classes
jar copied: 
- jaxb-api.jar
- Jaxb-impl.jar
- Jaxb-xjc.jar
- Jaxp-ri-1.4.2.jar
- Jaxws-api.jar
- Jaxws-rt.jar
- Jaxws-tools.jar
- Webservices-api.jar
- Webservices-rt.jar

Windows Server 2003 EE - 32 ビットにインストールされている RSA 7.5 (Rational Software Architect) に含まれている WAS 7.0 を使用して、アプリケーションを展開します。これまでのところ、公開されたメソッドをテストクエリして、期待される応答を取得します

問題:

Linux (RedHat) カーネル 2.6.18 - 64 ビットにインストールされている WAS 7.0 に EAR をデプロイすると、問題が発生します。

この場合、承認されていないディレクトリを作成し、物理的に配置されている上記の各ディレクトリに jar を配置する必要がありました。

Endorsed: / opt / IBM / WebSphere / AppServer / java / jre / lib / endorsed
classes: / opt/IBM/WebSphere/AppServer/profiles/AppSrv01/classes

次に、テストを実行すると、トレースで次のエラーが発生します。

[01/20/2012 9:11:54] ERROR [class: pe.gob.pj.WsBiometriaImpl] error
javax.xml.ws.WebServiceException: java.lang.NoSuchMethodError: com / sun / xml / stream / buffer / Stax / StreamWriterBufferCreator.setCheckAttributeValue (Z) V
 at com.sun.xml.wss.jaxws.impl.SecurityClientTube.processRequest (SecurityClientTube.java: 170)
 at com.sun.xml.ws.api.pipe.Fiber.__doRun (Fiber.java: 598)
 at com.sun.xml.ws.api.pipe.Fiber._doRun (Fiber.java: 557)
 at com.sun.xml.ws.api.pipe.Fiber.doRun (Fiber.java: 542)
 at com.sun.xml.ws.api.pipe.Fiber.runSync (Fiber.java: 439)
 at com.sun.xml.ws.client.Stub.process (Stub.java: 222)
 at com.sun.xml.ws.client.sei.SEIStub.doProcess (SEIStub.java: 135)
 at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke (SyncMethodHandler.java: 109)
 at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke (SyncMethodHandler.java: 89)
 at com.sun.xml.ws.client.sei.SEIStub.invoke (SEIStub.java: 118)
 at $ Proxy158.login (Unknown Source)
 at reniec.ws.AccessWS.loginWSBIO (AccessWS.java: 36)
 at pe.gob.pj.WsBiometriaImpl.loginWSBIO (WsBiometriaImpl.java: 74)
 at sun.reflect.NativeMethodAccessorImpl.invoke0 (Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java: 45)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorImpl.java: 37)
 at java.lang.reflect.Method.invoke (Method.java: 599)
 com.sun.xml.ws.api.server.InstanceResolver at $ 1.invoke (InstanceResolver.java: 246)
 com.sun.xml.ws.server.InvokerTube at $ 2.invoke (InvokerTube.java: 146)
 at com.sun.xml.ws.server.sei.EndpointMethodHandler.invoke (EndpointMethodHandler.java: 257)
 at com.sun.xml.ws.server.sei.SEIInvokerTube.processRequest (SEIInvokerTube.java: 93)
 at com.sun.xml.ws.api.pipe.Fiber.__doRun (Fiber.java: 598)
 at com.sun.xml.ws.api.pipe.Fiber._doRun (Fiber.java: 557)
 at com.sun.xml.ws.api.pipe.Fiber.doRun (Fiber.java: 542)
 at com.sun.xml.ws.api.pipe.Fiber.runSync (Fiber.java: 439)
 com.sun.xml.ws.server.WSEndpointImpl at $ 2.process (WSEndpointImpl.java: 243)
 com.sun.xml.ws.transport.http.HttpAdapter at $ HttpToolkit.handle (HttpAdapter.java: 444)
 at com.sun.xml.ws.transport.http.HttpAdapter.handle (HttpAdapter.java: 244)
 at com.sun.xml.ws.transport.http.servlet.ServletAdapter.handle (ServletAdapter.java: 135)
 at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doGet (WSServletDelegate.java: 129)
 at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doPost (WSServletDelegate.java: 160)
 at com.sun.xml.ws.transport.http.servlet.WSServlet.doPost (WSServlet.java: 75)
 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: 445)
 at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest (HttpInboundLink.java: 504)
 at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest (HttpInboundLink.java: 301)
 at com.ibm.ws.http.channel.inbound.impl.HttpICLReadCallback.complete (HttpICLReadCallback.java: 83)
 at
 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)
 com.ibm.io.async.ResultHandler at $ 2.run (ResultHandler.java: 905)
 at com.ibm.ws.util.ThreadPool $ Worker.run (ThreadPool.java: 1604)
Caused by: java.lang.NoSuchMethodError: com / sun / xml / stream / buffer / Stax / StreamWriterBufferCreator.setCheckAttributeValue (Z) V
 at com.sun.xml.ws.security.opt.impl.message.SOAPBody.cachePayLoad (SOAPBody.java: 204)
 at com.sun.xml.ws.security.opt.impl.dsig.SignedMessagePart.writeTo (SignedMessagePart.java: 147)
 at com.sun.xml.ws.security.opt.impl.crypto.JAXBDataImpl.writeTo (JAXBDataImpl.java: 117)
 at com.sun.xml.ws.security.opt.crypto.dsig.Exc14nCanonicalizer.transform (Exc14nCanonicalizer.java: 181)
 at com.sun.xml.ws.security.opt.crypto.dsig.Transform.transform (Transform.java: 178)
 at com.sun.xml.ws.security.opt.crypto.dsig.Reference.transform (Reference.java: 183)
 at com.sun.xml.ws.security.opt.crypto.dsig.Reference.digest (Reference.java: 124)
 at com.sun.xml.ws.security.opt.crypto.dsig.Signature.sign (Signature.java: 214)
 at com.sun.xml.ws.security.opt.impl.dsig.SignatureProcessor.sign (SignatureProcessor.java: 122)
 at com.sun.xml.wss.impl.filter.SignatureFilter.sign (SignatureFilter.java: 544)
 at com.sun.xml.wss.impl.filter.SignatureFilter.process (SignatureFilter.java: 506)
 at com.sun.xml.wss.impl.HarnessUtil.processWSSPolicy (HarnessUtil.java: 93)
 at com.sun.xml.wss.impl.HarnessUtil.processDeep (HarnessUtil.java: 268)
 at com.sun.xml.wss.impl.SecurityAnnotator.processMessagePolicy (SecurityAnnotator.java: 186)
 at com.sun.xml.wss.impl.SecurityAnnotator.secureMessage (SecurityAnnotator.java: 147)
 at com.sun.xml.wss.jaxws.impl.SecurityTubeBase.secureOutboundMessage (SecurityTubeBase.java: 390)
 at
 at com.sun.xml.wss.jaxws.impl.SecurityClientTube.processRequest (SecurityClientTube.java: 167)
 ... 53 more

問題の原因またはそれを修正する方法について何か考えを教えていただければ幸いです

4

1 に答える 1

4

作成した承認済みディレクトリがそのように認識されていないようです。

IBM は、WAS 7.0 のドキュメントで別のアプローチを推奨しています。

サードパーティの JAX-WS Web サービス エンジンの使用

于 2012-01-24T20:47:20.773 に答える