endpointreferencehelper.java
来自「开源的axis2框架的源码。用于开发WEBSERVER」· Java 代码 · 共 378 行 · 第 1/2 页
JAVA
378 行
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.axis2.addressing;
import org.apache.axiom.om.OMAttribute;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axiom.om.OMNode;
import org.apache.axiom.om.impl.builder.StAXOMBuilder;
import org.apache.axiom.om.util.AttributeHelper;
import org.apache.axiom.om.util.ElementHelper;
import org.apache.axiom.soap.SOAPFactory;
import org.apache.axis2.AxisFault;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLStreamException;
import java.io.ByteArrayInputStream;
import java.util.ArrayList;
import java.util.IdentityHashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
/**
* The methods in this class are used to process {@link EndpointReference} objects
* according to the rules of the 2005/08 (Final) and 2004/08 (submission) WS-Addressing
* specifications.
*/
public class EndpointReferenceHelper {
private static final Log log = LogFactory.getLog(EndpointReferenceHelper.class);
private final static Map finalQNames = new IdentityHashMap();
private final static Map submissionQNames = new IdentityHashMap();
/**
* Populates an endpoint reference based on the <code>OMElement</code> and
* WS-Addressing namespace that is passed in. If the string passed in is not
* recognized as a valid WS-Addressing namespace then this method behaves as
* if http://www.w3.org/2005/08/addressing has been passed in.
*
* @param epr an endpoint reference instance to hold the info.
* @param eprOMElement an element of endpoint reference type
* @param addressingNamespace the namespace of the WS-Addressing spec to comply with.
* @throws AxisFault if unable to locate an address element
* @see #fromOM(OMElement)
*/
public static void fromOM(EndpointReference epr, OMElement eprOMElement,
String addressingNamespace) throws AxisFault {
boolean isFinalAddressingNamespace = false;
Map map = null;
//First pass, identify the addressing namespace.
if (AddressingConstants.Submission.WSA_NAMESPACE.equals(addressingNamespace)) {
OMElement address = eprOMElement.getFirstChildWithName(
(QName) submissionQNames.get(AddressingConstants.EPR_ADDRESS));
if (address != null) {
map = submissionQNames;
isFinalAddressingNamespace = false;
if (log.isDebugEnabled()) {
log.debug("fromOM: Found address element for namespace, " +
AddressingConstants.Submission.WSA_NAMESPACE);
}
} else {
throw new AxisFault(
"Unable to locate an address element for the endpoint reference type.");
}
} else {
OMElement address = eprOMElement.getFirstChildWithName(
(QName) finalQNames.get(AddressingConstants.EPR_ADDRESS));
if (address != null) {
map = finalQNames;
isFinalAddressingNamespace = true;
if (log.isDebugEnabled()) {
log.debug("fromOM: Found address element for namespace, " +
AddressingConstants.Final.WSA_NAMESPACE);
}
} else {
throw new AxisFault(
"Unable to locate an address element for the endpoint reference type.");
}
}
//Second pass, identify the properties.
fromOM(epr, eprOMElement, map, isFinalAddressingNamespace);
}
/**
* Populates an endpoint reference based on the <code>String</code> that is
* passed in. If the http://schemas.xmlsoap.org/ws/2004/08/addressing namespace
* is in effect then any reference properties will be saved as reference parameters.
* Regardless of the addressing namespace in effect, any elements present in the
* <code>String</code> that are not recognised are saved as extensibility elements.
*
* @param eprString string from the element of endpoint reference type
* @throws AxisFault if unable to locate an address element
*/
public static EndpointReference fromOM(String eprString) throws AxisFault {
try {
return fromOM(new StAXOMBuilder(
new ByteArrayInputStream(eprString.getBytes())).getDocumentElement());
} catch (XMLStreamException e) {
throw AxisFault.makeFault(e);
}
}
/**
* Populates an endpoint reference based on the <code>OMElement</code> that is
* passed in. If the http://schemas.xmlsoap.org/ws/2004/08/addressing namespace
* is in effect then any reference properties will be saved as reference parameters.
* Regardless of the addressing namespace in effect, any elements present in the
* <code>OMElement</code> that are not recognised are saved as extensibility elements.
*
* @param eprOMElement an element of endpoint reference type
* @throws AxisFault if unable to locate an address element
*/
public static EndpointReference fromOM(OMElement eprOMElement) throws AxisFault {
EndpointReference epr = new EndpointReference("");
boolean isFinalAddressingNamespace = false;
Map map = null;
//First pass, identify the addressing namespace.
OMElement address = eprOMElement
.getFirstChildWithName((QName) finalQNames.get(AddressingConstants.EPR_ADDRESS));
if (address != null) {
map = finalQNames;
isFinalAddressingNamespace = true;
if (log.isDebugEnabled()) {
log.debug("fromOM: Found address element for namespace, " +
AddressingConstants.Final.WSA_NAMESPACE);
}
} else {
address = eprOMElement.getFirstChildWithName(
(QName) submissionQNames.get(AddressingConstants.EPR_ADDRESS));
if (address != null) {
map = submissionQNames;
isFinalAddressingNamespace = false;
if (log.isDebugEnabled()) {
log.debug("fromOM: Found address element for namespace, " +
AddressingConstants.Submission.WSA_NAMESPACE);
}
} else {
throw new AxisFault(
"Unable to locate an address element for the endpoint reference type.");
}
}
//Second pass, identify the properties.
fromOM(epr, eprOMElement, map, isFinalAddressingNamespace);
return epr;
}
/**
* Creates an <code>OMElement</code> based on the properties of the endpoint
* reference. The output may differ based on the addressing namespace that is
* in effect when this method is called. If the http://www.w3.org/2005/08/addressing
* namespace is in effect, and a metadata property has been defined for the
* endpoint reference, then there will be a metadata element to contain the
* property in the output. If the http://schemas.xmlsoap.org/ws/2004/08/addressing
* namespace is in effect, however, then no metadata element will be included
* in the output, even if a metadata property element has been defined.
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?