Uploaded image for project: 'JBoss Enterprise Application Platform 4 and 5'
  1. JBoss Enterprise Application Platform 4 and 5
  2. JBPAPP-6285

Backport fix for org.w3c.dom.DOMException when creating dispatch with EPR

    XMLWordPrintable

Details

    • Bug
    • Resolution: Done
    • Major
    • EAP_EWP 5.1.2 ER1
    • EAP 5.0.1
    • Web Services
    • None
    • Hide
      JBoss Web Services threw an org.w3c.dom.DOMException when it attempted to create a dispatch client with an EnpointReference. This happened because the server appended a node from another document to the dispatch client in some concurrent environments. JBoss Web Services now appends the correct node to the dispatch client and creates the dispatch client with an EndpointReference correctly.
      Show
      JBoss Web Services threw an org.w3c.dom.DOMException when it attempted to create a dispatch client with an EnpointReference. This happened because the server appended a node from another document to the dispatch client in some concurrent environments. JBoss Web Services now appends the correct node to the dispatch client and creates the dispatch client with an EndpointReference correctly.
    • Documented as Resolved Issue
    • NEW

    Description

      0:40:43,972 INFO [STDOUT] WS ADDR=<?xml version="1.0"
      encoding="UTF-8" standalone="yes"?><EndpointReference
      xmlns="http://www.w3.org/2005/08/addressing"><Address>http://localhost:8080/Quickstart_bpel_simple_invoke/HelloWorldWS</Address><Metadata><wsam:ServiceName
      EndpointName="HelloWorldPort" xmlns="http://simple_invoke/helloworld"
      xmlns:wsam="http://www.w3.org/2007/05/addressing/metadata">HelloWorldWSService</wsam:ServiceName></Metadata></EndpointReference>
      10:40:44,153 ERROR [HandlerChainExecutor] Exception during handler
      processing
      org.w3c.dom.DOMException: WRONG_DOCUMENT_ERR: A node is used in a
      different document than the one that created it.
      at org.apache.xerces.dom.ParentNode.internalInsertBefore(Unknown
      Source)
      at org.apache.xerces.dom.ParentNode.insertBefore(Unknown Source)
      at org.apache.xerces.dom.NodeImpl.appendChild(Unknown Source)
      at org.jboss.ws.core.soap.NodeImpl.appendChild(NodeImpl.java:481)
      at
      org.jboss.ws.core.soap.SOAPHeaderImpl.appendChild(SOAPHeaderImpl.java:198)
      at
      org.jboss.ws.core.soap.SOAPElementImpl.addChildElement(SOAPElementImpl.java:264)
      at
      org.jboss.ws.core.soap.SOAPHeaderImpl.addChildElement(SOAPHeaderImpl.java:70)
      at
      org.jboss.ws.core.soap.SOAPElementImpl.addChildElement(SOAPElementImpl.java:233)
      at
      org.jboss.ws.extensions.addressing.soap.SOAPAddressingPropertiesImpl.writeHeaders(SOAPAddressingPropertiesImpl.java:267)
      at
      org.jboss.ws.extensions.addressing.jaxws.WSAddressingClientHandler.handleOutbound(WSAddressingClientHandler.java:139)
      at
      org.jboss.wsf.common.handler.GenericHandler.handleMessage(GenericHandler.java:53)
      at
      org.jboss.ws.core.jaxws.handler.HandlerChainExecutor.handleMessage(HandlerChainExecutor.java:328)
      at
      org.jboss.ws.core.jaxws.handler.HandlerChainExecutor.handleMessage(HandlerChainExecutor.java:146)
      at
      org.jboss.ws.core.jaxws.client.DispatchImpl.callRequestHandlerChain(DispatchImpl.java:640)
      at
      org.jboss.ws.core.jaxws.client.DispatchImpl.invokeInternalSOAP(DispatchImpl.java:256)
      at
      org.jboss.ws.core.jaxws.client.DispatchImpl.invokeInternal(DispatchImpl.java:180)
      at
      org.jboss.ws.core.jaxws.client.DispatchImpl.invoke(DispatchImpl.java:147)
      at
      org.jboss.soa.bpel.runtime.ws.WebServiceClient$TwoWayCallable$1.call(WebServiceClient.java:355)
      at
      org.apache.ode.scheduler.simple.SimpleScheduler.execTransaction(SimpleScheduler.java:289)
      at
      org.apache.ode.scheduler.simple.SimpleScheduler.execTransaction(SimpleScheduler.java:246)
      at
      org.jboss.soa.bpel.runtime.ws.WebServiceClient$TwoWayCallable.call(WebServiceClient.java:231)
      at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
      at java.util.concurrent.FutureTask.run(FutureTask.java:138)
      at
      java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
      at
      java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
      at java.lang.Thread.run(Thread.java:619)

      Only thing I am doing is:

      org.apache.ode.bpel.iapi.EndpointReference
      odeepr=mex.getEndpointReference();
      javax.xml.ws.EndpointReference epr=null;

      if (odeepr != null) {
      if (odeepr instanceof org.apache.ode.bpel.epr.URLEndpoint) {
      org.apache.ode.bpel.epr.URLEndpoint
      url=(org.apache.ode.bpel.epr.URLEndpoint)odeepr;

      javax.xml.ws.wsaddressing.W3CEndpointReferenceBuilder builder=
      new javax.xml.ws.wsaddressing.W3CEndpointReferenceBuilder();

      epr = builder.address(url.getUrl())
      .serviceName(serviceName)
      .endpointName(port)
      .build();

      System.out.println("WS ADDR="+epr);

      Creating the EPR from the ODE endpoint reference, and then

      if (epr != null) {
      dispatcher = service.createDispatch(
      epr,
      SOAPMessage.class,
      Service.Mode.MESSAGE,
      new javax.xml.ws.soap.AddressingFeature()
      );

      Attachments

        Issue Links

          Activity

            People

              rh-ee-klape Kyle Lape
              rh-ee-klape Kyle Lape
              Eva Kopalova Eva Kopalova (Inactive)
              Votes:
              0 Vote for this issue
              Watchers:
              0 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: