The example from Apache below should help:


/*
 * The Apache Software License, Version 1.1
 *
 *
 * Copyright (c) 1999, 2000 The Apache Software Foundation.  All rights
 * reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * 3. The end-user documentation included with the redistribution,
 *    if any, must include the following acknowledgment:
 *       "This product includes software developed by the
 *        Apache Software Foundation (http://www.apache.org/)."
 *    Alternately, this acknowledgment may appear in the software itself,
 *    if and wherever such third-party acknowledgments normally appear.
 *
 * 4. The names "Xerces" and "Apache Software Foundation" must
 *    not be used to endorse or promote products derived from this
 *    software without prior written permission. For written
 *    permission, please contact [EMAIL PROTECTED]
 *
 * 5. Products derived from this software may not be called "Apache",
 *    nor may "Apache" appear in their name, without prior written
 *    permission of the Apache Software Foundation.
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 * ====================================================================
 *
 * This software consists of voluntary contributions made by many
 * individuals on behalf of the Apache Software Foundation and was
 * originally based on software copyright (c) 1999, International
 * Business Machines, Inc., http://www.apache.org.  For more
 * information on the Apache Software Foundation, please see
 * <http://www.apache.org/>.
 */

package dom.wrappers;

import dom.DOMParserWrapper;

import org.w3c.dom.Document;

import org.xml.sax.ErrorHandler;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import org.xml.sax.SAXNotRecognizedException;
import org.xml.sax.SAXNotSupportedException;
import org.apache.xml.serialize.XMLSerializer;

import org.apache.xml.serialize.BaseMarkupSerializer;
import org.apache.xml.serialize.OutputFormat;
import org.xml.sax.InputSource;

import java.io.*;

import org.apache.xerces.parsers.*;
import org.apache.xerces.framework.*;

/**
 * Wraps the Xerces DOM parser and extends NonValidatingDOMParser
 *
 * @version  $id$
 */
public class DOMParser
    implements DOMParserWrapper, ErrorHandler {

    //
    // Data
    //



    /** Parser. */
    org.apache.xerces.parsers.DOMParser parser =
        new org.apache.xerces.parsers.DOMParser();

    //
    // Constructors
    //

    /** Default constructor. */
    public DOMParser() {
        try {
            parser.setFeature( "http://xml.org/sax/features/validation";,
true);

        } catch (SAXException e) {
            System.out.println("error in setting up parser feature");
        }

        parser.setErrorHandler(this);

    }

        public org.apache.xerces.parsers.DOMParser getParser()
        {
                return parser;
        }

    //
    // DOMParserWrapper methods
    //

    /** Parses the specified URI and returns the document. */
    public Document parse(String uri) throws Exception {
        parser.parse(uri);
        return parser.getDocument();

    } // parse(String):Document


    public void     setFeature(String featureId, boolean state)
            throws  SAXNotRecognizedException, SAXNotSupportedException {
            parser.setFeature( featureId, state );
    }



    //
    // ErrorHandler methods
    //

    /** Warning. */
    public void warning(SAXParseException ex) {
        System.err.println("[Warning] "+
                           getLocationString(ex)+": "+
                           ex.getMessage());
    }

    /** Error. */
    public void error(SAXParseException ex) {
        System.err.println("[Error] "+
                           getLocationString(ex)+": "+
                           ex.getMessage());
    }

    /** Fatal error. */
    public void fatalError(SAXParseException ex) throws SAXException {
        System.err.println("[Fatal Error] "+
                           getLocationString(ex)+": "+
                           ex.getMessage());
        throw ex;
    }

    //
    // Private methods
    //

    /** Returns a string of the location. */
    private String getLocationString(SAXParseException ex) {
        StringBuffer str = new StringBuffer();

        String systemId = ex.getSystemId();
        if (systemId != null) {
            int index = systemId.lastIndexOf('/');
            if (index != -1)
                systemId = systemId.substring(index + 1);
            str.append(systemId);
        }
        str.append(':');
        str.append(ex.getLineNumber());
        str.append(':');
        str.append(ex.getColumnNumber());

        return str.toString();

    } // getLocationString(SAXParseException):String

        public static void main(String args[]) throws Exception
  {
        DOMParser dp = new DOMParser();
        org.w3c.dom.Document doc = dp.parse("/covermaker/business by
design/response.xml");


        // TO READ THE XML AS IT ARRIVES, SEE:
http://xml.apache.org/xerces-j/faq-write.html

        // now create the serializer
        OutputFormat of = new OutputFormat( "xml", "UTF-8", true );
        XMLSerializer domXMLSerializer = new XMLSerializer( of );
        domXMLSerializer.setOutputByteStream( new
ileOutputStream( "/covermaker/business by
design/re-serialized_response.xml" ) );
        domXMLSerializer.serialize( doc.getDocumentElement() );
  }

} // class DOMParser

-----Original Message-----
From: Pete Roth [mailto:[EMAIL PROTECTED]]
Sent: 31 July 2001 18:20
To: Soap-user list (E-mail); Soap-dev List (E-mail)
Subject: Using Xerces to parse a SOAP response


Does anyone know of an example or how to use the response from a SOAP
request in a Java client to build a Xerces object?  What I would like to do
is parse the XML returned from the SOAP service.  The response object allows
you to get a Parameter Object.  The Parameter.getValue() method returns an
Object.  When using a simple SOAP method which only returns one piece of
data I just displayed that Object as a String and that worked fine.  Now I'm
trying to parse the data returned when there is complex XML returned by the
SOAP service.  Can this Object be used to build a Reader(or XMLReader or
however Xerces specifically works) which will allow me to select nodes using
Xerces?

If anyone could help me I would greatly appreciate it.  Even a link to some
examples of using the response from in a Java client using the Apache
packages to build a DOM document or something similar would be great.

Thanks.

Peter Roth
Telemetry Technologies Inc.
p: 404.231.0021 ext. 1290
e: [EMAIL PROTECTED]

Reply via email to