2017-03-31 9 views
0

Jboss 5 WebサービスをJboss EAP 7に移行しています。このサービスを呼び出すと、生成されたSOAP要求が2つのタグエラー応答をもたらす。Jboss EAP 7 Webサービスの問題「オペレーションをアンワップできませんでした」、間違ったSOAP要求が生成される

まず、私は警告を参照してください。私は警告が以下の、されているメソッドが一致していないが、私はそれが真実であるとは思わないと言うことを理解し、操作

09:53:10,936 INFO [org.apache.cxf.wsdl.service.factory.ReflectionServiceFactoryBean] (default task-24) Creating Service {Crmr5100}Crmr5100 from WSDL: http://intwsdev.internal.myservices:8080/crm/services/Crmr5100?wsdl 
09:53:11,069 WARNING [org.apache.cxf.wsdl.service.factory.ReflectionServiceFactoryBean] (default task-24) Could not unwrap Operation {Crmr5100}Crmr5100AdditionalIdDetail to match method "public abstract void webservices.stubs.crmr5100.Crmr5100Port.crmr5100AdditionalIdDetail(webservices.stubs.crmr5100.Crmr5100AdditionalIdDetail$Request,javax.xml.ws.Holder,javax.xml.ws.Holder)" 

のラップを解除できませんでした私の生成されたポート・インターフェース

/** 
    * This class was generated by the JAX-WS RI. 
    * JAX-WS RI 2.1.3.2-02/08/2010 05:22 PM(mockbuild)-SNAPSHOT 
    * Generated source version: 2.0 
    */ 
@WebService(name = "Crmr5100Port", targetNamespace = "Crmr5100") 
public interface Crmr5100Port { 

    /** 
     * 
     * @param response 
     * @param error 
     * @param request 
     */ 
    @WebMethod(operationName = "Crmr5100AdditionalIdDetail", action = "Crmr5100") 
    @RequestWrapper(localName = "Crmr5100AdditionalIdDetail", targetNamespace = "Crmr5100", className = "webservices.stubs.crmr5100.Crmr5100AdditionalIdDetail") 
    @ResponseWrapper(localName = "Crmr5100AdditionalIdDetailResponse", targetNamespace = "Crmr5100", className = "webservices.stubs.crmr5100.Crmr5100AdditionalIdDetailResponse") 
    public void crmr5100AdditionalIdDetail( 
     @WebParam(name = "request", targetNamespace = "") 
     webservices.stubs.crmr5100.Crmr5100AdditionalIdDetail.Request request, 

     @WebParam(name = "response", targetNamespace = "", mode = WebParam.Mode.OUT) 
     Holder<webservices.stubs.crmr5100.Crmr5100AdditionalIdDetailResponse.Response> response, 
     @WebParam(name = "error", targetNamespace = "", mode = WebParam.Mode.OUT) 
     Holder<webservices.stubs.crmr5100.Crmr5100AdditionalIdDetailResponse.Error> error); 
} 

そして、これは私がサービス、wsInterfaceFactory.getPortを(呼び出しています方法ですが)ただjavax.xml.ws.Service(URLのURL、新しいのQName(名前空間、serviceNameの)を呼び出し、そして、のgetPort(新しいのQName(名前空間のportName)、portClassは)スニペット以下

   Crmr5100Port ws = wsInterfaceFactory.getPort(Crmr5100Port.class); 
       Crmr5100AdditionalIdDetail.Request request = new Crmr5100AdditionalIdDetail.Request(); 
       request.setCommand("OPEN"); 
       request.setClientId(credentials.getUsername()); 
       request.setClientPassword(credentials.getWebServicePassword()); 
       request.setComCfg(systemOptions.getOptionValueAsString("COMCFG")); 
       Crmr5100AdditionalIdDetail.Request.ImportImap1AdditionalId importAddn = new Crmr5100AdditionalIdDetail.Request.ImportImap1AdditionalId(); 
       importAddn.setId(BigInteger.valueOf(a_additionalId)); 
       importAddn.setAdditionalId(a_aiNumber); 
       request.setImportImap1AdditionalId(importAddn); 
       Holder<webservices.stubs.crmr5100.Crmr5100AdditionalIdDetailResponse.Response> response = new Holder<>(); 
       Holder<webservices.stubs.crmr5100.Crmr5100AdditionalIdDetailResponse.Error> error = new Holder<>(); 
       ws.crmr5100AdditionalIdDetail(request, response, error); 
       if (error.value == null && response.value != null) { 
        Crmr5100AdditionalIdDetailResponse.Response res = response.value; 
        // Do something with my response 
       } 

は、私は、JBoss EAP 7サーバー上でサービスを呼び出すときに、コンソールに私のSOAPHandlerで印刷されますSOAP要求がある

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"> 
    <SOAP-ENV:Header xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"/> 
    <soap:Body> 
    <ns2:Crmr5100AdditionalIdDetail xmlns:ns2="Crmr5100" clientId="AMORAM" clientPassword="XXXXX" comCfg="TCP myserv4sprhgend1 4275" command="OPEN"> 
     <ImportImap1AdditionalId> 
     <Id>368638372002136</Id> 
     <AdditionalId>WQ0013966001</AdditionalId> 
     </ImportImap1AdditionalId> 
    </ns2:Crmr5100AdditionalIdDetail> 
    </soap:Body> 
</soap:Envelope> 

上記のコードをスタンドアロンのJavaプログラム(メインメソッドでサービスを呼び出す)またはSOAP UIを使用して実行すると、同じopeartionに対して生成されるSOAP要求は以下のとおりです。その内容は前のタグに統合されました

<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/"> 
    <S:Body> 
     <ns2:Crmr5100AdditionalIdDetail xmlns:ns2="Crmr5100"> 
      <request command="OPEN" clientId="AMORAM" clientPassword="XXXXX" comCfg="TCP myserv4sprhgend1 4275"> 
       <ImportImap1AdditionalId> 
        <Id>368638372002136</Id> 
        <AdditionalId>WQ0013966001</AdditionalId> 
       </ImportImap1AdditionalId> 
      </request> 
     </ns2:Crmr5100AdditionalIdDetail> 
    </S:Body> 
</S:Envelope> 

これがJboss内部Webサービスの問題であるかどうかはわかりません。 jbossが使用するjarファイルを見つけるためにmodules.xmlを貼り付けました。ない限り、I Iは、(私はできれば避けたいそれらの一つは、彼がCXFで再生することを述べている既存のpostを見て、とJBossコミュニティhere

modules.xml

<module xmlns="urn:jboss:module:1.3" name="org.apache.cxf.impl"> 

<properties> 
    <property name="jboss.api" value="private"/> 
</properties> 

<resources> 
    <resource-root path="cxf-rt-bindings-coloc-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-bindings-object-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-bindings-soap-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-bindings-xml-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-databinding-aegis-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-databinding-jaxb-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-frontend-jaxws-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-frontend-simple-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-management-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-security-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-security-saml-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-transports-http-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-transports-http-hc-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-transports-jms-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-transports-local-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-wsdl-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-ws-addr-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-ws-mex-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-ws-policy-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-rt-ws-rm-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-common-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-java2ws-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-validator-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-wsdlto-core-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-wsdlto-databinding-jaxb-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-tools-wsdlto-frontend-jaxws-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-services-ws-discovery-api-3.1.4.redhat-1.jar"/> 
    <resource-root path="cxf-xjc-boolean-3.0.5.redhat-1.jar"/> 
    <resource-root path="cxf-xjc-bug986-3.0.5.redhat-1.jar"/> 
    <resource-root path="cxf-xjc-dv-3.0.5.redhat-1.jar"/> 
    <resource-root path="cxf-xjc-ts-3.0.5.redhat-1.jar"/> 
    <resource-root path="cxf-xjc-runtime-3.0.5.redhat-1.jar"/> 
</resources> 
<dependencies> 
... 
</dependencies> 

私は信じている別の問題です。

ご協力いただきまして誠にありがとうございます。

おかげで、

アビ

答えて

0

私は実際に再生成スタブを避けるためにしようとしているが、JBossのEAP 7は、サービスを実行するために内部CXFを使用してのように見えました。以前はJAX-WSを使用してスタブを生成していましたが、Jboss 5は内部的にJAX-WSを使用していました。

結論として、この種のサービス実装でJAX-WSを使用して生成されたスタブは、スタブ生成ツールのいずれかを使用してスタブを再生成する以外の方法はありません。私は、Apache CXFとポート .javaファイルが

/** 
* This class was generated by Apache CXF 3.1.10 
* 2017-04-07T11:01:43.951-05:00 
* Generated source version: 3.1.10 
* 
*/ 
@WebService(targetNamespace = "Crmr5100", name = "Crmr5100Port") 
@XmlSeeAlso({ObjectFactory.class}) 
@SOAPBinding(parameterStyle = SOAPBinding.ParameterStyle.BARE) 
public interface Crmr5100Port { 

    @WebMethod(operationName = "Crmr5100AdditionalIdDetail", action = "Crmr5100") 
    @WebResult(name = "Crmr5100AdditionalIdDetailResponse", targetNamespace = "Crmr5100", partName = "Crmr5100AdditionalIdDetail") 
    public Crmr5100AdditionalIdDetailResponse crmr5100AdditionalIdDetail(
     @WebParam(partName = "Crmr5100AdditionalIdDetail", name = "Crmr5100AdditionalIdDetail", targetNamespace = "Crmr5100") 
     Crmr5100AdditionalIdDetail crmr5100AdditionalIdDetail 
    ); 
} 

そしてSOAPリクエストが適切なフォーマットで生成される方法異なる少なくとも生成されたスタブを使用していました。

実際の質問は、スタブを再生成せずに解決策を見つけることでした。スタブを再生成する以外の方法はないので、私が固定した方法が唯一の方法だと思う。それで、それを答えたものとしてマーキングする。私が間違っている場合は修正してください。

ありがとう、 Avinash

関連する問題