⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 javabeanfaultwriter.java

📁 Java有关XML编程需要用到axis 的源代码 把里面bin下的包导入相应的Java工程 进行使用
💻 JAVA
字号:
/* * Copyright 2001-2004 The Apache Software Foundation. *  * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *  *      http://www.apache.org/licenses/LICENSE-2.0 *  * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.axis.wsdl.toJava;import org.apache.axis.wsdl.symbolTable.TypeEntry;import java.io.IOException;import java.io.PrintWriter;import java.util.Vector;import java.util.Set;import java.util.Collections;import java.util.HashSet;/** * This is Wsdl2java's Complex Fault Writer. * It generates bean-like class for complexTypes used * in an operation fault message. */public class JavaBeanFaultWriter extends JavaBeanWriter {    /**     * All server specific exception classes have {@link Throwable} as an     * indirect superclass. <code>Throwable</code> defines a set of properties     * that may potentially conflict with those that would be generated by     * this class for an XSD complex type used as a fault. The following     * immutable object contains all property names that must be excluded     * when generating a service specific exception. <i>Note:</t>     * {@link org.apache.axis.encoding.ser.BeanSerializer} always excludes     * <code>Throwable</code>'s and  <code>AxisFault</code>'s properties     * when marshalling a service Java exception.     */    public static final Set   RESERVED_PROPERTY_NAMES;    static {        Set   temp = new HashSet();        // Throwable's properties.        temp.add("cause");        temp.add("message");        temp.add("localizedMessage");        temp.add("stackTrace");        // AxisFault's properties.        temp.add("faultActor");        temp.add("faultCode");        temp.add("faultDetails");        temp.add("faultNode");        temp.add("faultReason");        temp.add("faultRole");        temp.add("faultString");        temp.add("faultSubCodes");        temp.add("headers");        RESERVED_PROPERTY_NAMES = Collections.unmodifiableSet(temp);    }    /**     * Constructor.     *      * @param emitter         * @param type       The type representing this class     * @param elements   Vector containing the Type and name of each property     * @param extendType The type representing the extended class (or null)     * @param attributes Vector containing the attribute types and names     * @param helper     Helper class writer     */    protected JavaBeanFaultWriter(Emitter emitter, TypeEntry type,                                  Vector elements, TypeEntry extendType,                                  Vector attributes, JavaWriter helper) {        super(emitter, type, elements, extendType, attributes, helper);        // The Default Constructor is not JSR 101 v1.0 compliant, but        // is the only way that Axis can get something back over the wire.        // This will need to be changed when fault contents are supported        // over the wire.        enableDefaultConstructor = true;        // JSR 101 v1.0 requires a full constructor        enableFullConstructor = true;        // JSR 101 v1.0 does not support write access methods        enableSetters = true;    }    // ctor    /**     * Returns the appropriate extends text     *      * @return "" or " extends <class> "     */    protected String getExtendsText() {        // See if this class extends another class        String extendsText = super.getExtendsText();        if (extendsText.equals("")) {            // JSR 101 compliant code should extend java.lang.Exception!            // extendsText = " extends java.lang.Exception ";            extendsText = " extends org.apache.axis.AxisFault ";        }        return extendsText;    }    /**     * Write the Exception serialization code     * <p/>     * NOTE: This function is written in JavaFaultWriter.java also.     *      * @param pw      * @throws IOException      */    protected void writeFileFooter(PrintWriter pw) throws IOException {        // We need to have the Exception class serialize itself        // with the correct namespace, which can change depending on which        // operation the exception is thrown from.  We therefore have the        // framework call this generated routine with the correct QName,        // and allow it to serialize itself.        // method that serializes this exception (writeDetail)        pw.println();        pw.println("    /**");        pw.println("     * Writes the exception data to the faultDetails");        pw.println("     */");        pw.println(                "    public void writeDetails(javax.xml.namespace.QName qname, org.apache.axis.encoding.SerializationContext context) throws java.io.IOException {");        pw.println("        context.serialize(qname, null, this);");        pw.println("    }");        super.writeFileFooter(pw);    }    // writeFileFooter}    // class JavaBeanFaultWriter

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -