src/share/jaxws_classes/com/sun/xml/internal/messaging/saaj/util/RejectDoctypeSaxFilter.java

Thu, 31 Aug 2017 15:18:52 +0800

author
aoqi
date
Thu, 31 Aug 2017 15:18:52 +0800
changeset 637
9c07ef4934dd
parent 368
0989ad8c0860
parent 0
373ffda63c9a
permissions
-rw-r--r--

merge

     1 /*
     2  * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     5  * This code is free software; you can redistribute it and/or modify it
     6  * under the terms of the GNU General Public License version 2 only, as
     7  * published by the Free Software Foundation.  Oracle designates this
     8  * particular file as subject to the "Classpath" exception as provided
     9  * by Oracle in the LICENSE file that accompanied this code.
    10  *
    11  * This code is distributed in the hope that it will be useful, but WITHOUT
    12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    14  * version 2 for more details (a copy is included in the LICENSE file that
    15  * accompanied this code).
    16  *
    17  * You should have received a copy of the GNU General Public License version
    18  * 2 along with this work; if not, write to the Free Software Foundation,
    19  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    20  *
    21  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    22  * or visit www.oracle.com if you need additional information or have any
    23  * questions.
    24  */
    26 package com.sun.xml.internal.messaging.saaj.util;
    28 import java.util.logging.Logger;
    30 import javax.xml.parsers.SAXParser;
    31 import javax.xml.soap.SOAPException;
    33 import org.xml.sax.*;
    34 import org.xml.sax.ext.LexicalHandler;
    35 import org.xml.sax.helpers.XMLFilterImpl;
    37 import com.sun.xml.internal.messaging.saaj.SOAPExceptionImpl;
    38 import org.xml.sax.helpers.AttributesImpl;
    40 /**
    41  * Users of this class see a SAX2 XMLReader (via XMLFilterImpl).  This
    42  * class creates a parent XMLReader via JAXP and installs itself as a SAX2
    43  * extension LexicalHandler which rejects document type declarations
    44  * because they are not legal in SOAP.  If the user of this class sets a
    45  * LexicalHandler, then it forwards events to that handler.
    46  *
    47  *
    48  * @author Edwin Goei
    49  */
    51 public class RejectDoctypeSaxFilter extends XMLFilterImpl implements XMLReader, LexicalHandler{
    52     protected static final Logger log =
    53     Logger.getLogger(LogDomainConstants.UTIL_DOMAIN,
    54     "com.sun.xml.internal.messaging.saaj.util.LocalStrings");
    56     /** Standard SAX 2.0 ext property */
    57     static final String LEXICAL_HANDLER_PROP =
    58     "http://xml.org/sax/properties/lexical-handler";
    60     static final String WSU_NS = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd".intern();
    61     static final String SIGNATURE_LNAME = "Signature".intern();
    62     static final String ENCRYPTED_DATA_LNAME = "EncryptedData".intern();
    63     static final String DSIG_NS = "http://www.w3.org/2000/09/xmldsig#".intern();
    64     static final String XENC_NS = "http://www.w3.org/2001/04/xmlenc#".intern();
    65     static final String ID_NAME = "ID".intern();
    67     /** LexicalHandler to forward events to, if any */
    68     private LexicalHandler lexicalHandler;
    70     public RejectDoctypeSaxFilter(SAXParser saxParser) throws SOAPException {
    71         XMLReader xmlReader;
    72         try {
    73             xmlReader = saxParser.getXMLReader();
    74         } catch (Exception e) {
    75             log.severe("SAAJ0602.util.getXMLReader.exception");
    76             throw new SOAPExceptionImpl(
    77             "Couldn't get an XMLReader while constructing a RejectDoctypeSaxFilter",
    78             e);
    79         }
    81         // Set ourselves up to be the SAX LexicalHandler
    82         try {
    83             xmlReader.setProperty(LEXICAL_HANDLER_PROP, this);
    84         } catch (Exception e) {
    85             log.severe("SAAJ0603.util.setProperty.exception");
    86             throw new SOAPExceptionImpl(
    87             "Couldn't set the lexical handler property while constructing a RejectDoctypeSaxFilter",
    88             e);
    89         }
    91         // Set the parent XMLReader of this SAX filter
    92         setParent(xmlReader);
    93     }
    95     /*
    96      * Override setProperty() to capture any LexicalHandler that is set for
    97      * forwarding of events.
    98      */
    99     public void setProperty(String name, Object value)
   100     throws SAXNotRecognizedException, SAXNotSupportedException {
   101         if (LEXICAL_HANDLER_PROP.equals(name)) {
   102             lexicalHandler = (LexicalHandler) value;
   103         } else {
   104             super.setProperty(name, value);
   105         }
   106     }
   108     //
   109     // Beginning of SAX LexicalHandler callbacks...
   110     //
   112     public void startDTD(String name, String publicId, String systemId)
   113     throws SAXException {
   114         throw new SAXException("Document Type Declaration is not allowed");
   115     }
   117     public void endDTD() throws SAXException {
   118     }
   120     public void startEntity(String name) throws SAXException {
   121         if (lexicalHandler != null) {
   122             lexicalHandler.startEntity(name);
   123         }
   124     }
   126     public void endEntity(String name) throws SAXException {
   127         if (lexicalHandler != null) {
   128             lexicalHandler.endEntity(name);
   129         }
   130     }
   132     public void startCDATA() throws SAXException {
   133         if (lexicalHandler != null) {
   134             lexicalHandler.startCDATA();
   135         }
   136     }
   138     public void endCDATA() throws SAXException {
   139         if (lexicalHandler != null) {
   140             lexicalHandler.endCDATA();
   141         }
   142     }
   144     public void comment(char[] ch, int start, int length) throws SAXException {
   145         if (lexicalHandler != null) {
   146             lexicalHandler.comment(ch, start, length);
   147         }
   148     }
   150     //
   151     // End of SAX LexicalHandler callbacks
   152     //
   154     public void startElement(String namespaceURI, String localName,
   155     String qName, Attributes atts)   throws SAXException{
   156         if(atts != null ){
   157             boolean eos = false;
   158             if(namespaceURI == DSIG_NS || XENC_NS == namespaceURI){
   159                 eos = true;
   160             }
   161             int length = atts.getLength();
   162             AttributesImpl attrImpl = new AttributesImpl();
   163             for(int i=0; i< length;i++){
   164                 String name = atts.getLocalName(i);
   165                 if(name!=null && (name.equals("Id"))){
   166                     if(eos || atts.getURI(i) == WSU_NS ){
   167                         attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i),
   168                         atts.getQName(i), ID_NAME, atts.getValue(i));
   169                     }else{
   170                          attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i), atts.getQName(i), atts.getType(i), atts.getValue(i));
   171                     }
   172                 }else{
   173                     attrImpl.addAttribute(atts.getURI(i), atts.getLocalName(i),
   174                     atts.getQName(i), atts.getType(i), atts.getValue(i));
   175                 }
   176             }
   177             super.startElement(namespaceURI,localName, qName,attrImpl);
   178         }else{
   179             super.startElement(namespaceURI,localName, qName, null);
   180         }
   181     }
   182 }

mercurial