Веб-сервисы с библиотекой JAX WS-SUN в WAS 7.0 - PullRequest
4 голосов
/ 24 января 2012

КОНТЕКСТ ПРОБЛЕМЫ:

Я использую методы веб-службы, предоставляемые учреждением за пределами шахты, веб-служба была создана JAX WS-SUN. Внедрите другой веб-сервис для внутреннего потребления моего учреждения, который инкапсулирует методы, предоставляемые аутсорсером, используйте JAX WS-SUN (не IBM), изначально возникли некоторые проблемы с распознаванием некоторых jar. Попробуйте настроить общие библиотеки на сервере для использования jar с загрузчиком классов PARENT_LAST, и он не работает. Попробуйте reliza с библиотеками JAX WS-IBM, но безуспешно, так что сделайте это с JAX WS-SUN (библиотеки, используемые внешним поставщиком услуг) Затем я нашел решение, используя «одобренную» папку (эта папка уже существовала, но была пуста), которая находится в дереве каталогов sdk, включенном в WAS 7.0, и скопировала другой файл jar в папку «classes», которая физически расположена (в моем PC):

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

Для развертывания приложения с использованием WAS 7.0, включенного в RSA 7.5 (Rational Software Architect), который установлен в Windows Server 2003 EE - 32bit. Пока все хорошо, сделайте мои тестовые запросы открытыми методами и получите ожидаемый ответ

ПРОБЛЕМА:

Проблема возникает при развертывании EAR в WAS 7.0, который установлен на ядре Linux (RedHat) 2.6.18 - 64 бита.

В этом случае мне пришлось создать папку, в которой не было одобренного каталога, и поместить 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

Буду признателен, если вы дадите мне некоторое представление о происхождении проблемы или любом способе ее решения.

1 Ответ

4 голосов
/ 25 января 2012

Похоже, что созданный вами одобренный каталог не распознается как таковой.

IBM рекомендует использовать другой подход в своей документации для WAS 7.0.

Использование стороннего производителяМеханизм веб-служб JAX-WS

...