MessageFactory.java |
/* * JBoss, the OpenSource EJB server * * Distributable under LGPL license. * See terms of license at gnu.org. */ package javax.xml.soap; import java.io.IOException; import java.io.InputStream; /** * A factory for creating SOAPMessage objects. * * A SAAJ client can create a MessageFactory object using the method newInstance, as shown in the following line of code. * * MessageFactory mf = MessageFactory.newInstance(); * * A standalone client (a client that is not running in a container) can use the newInstance method to create a MessageFactory object. * * All MessageFactory objects, regardless of how they are created, will produce SOAPMessage objects that have the following elements by default: * * A SOAPPart object * A SOAPEnvelope object * A SOAPBody object * A SOAPHeader object * * MessageFactory objects can be initialized with a JAXM profile. In such a case it will produce messages that also * come prepopulated with additional entries in the SOAPHeader object and the SOAPBody object. The content of a new * SOAPMessage object depends on which of the two MessageFactory methods is used to create it. * * createMessage() -- message has no content * This is the method clients would normally use to create a request message. * * createMessage(MimeHeaders, java.io.InputStream) -- message has content from the InputStream object and headers from the MimeHeaders object * This method can be used internally by a service implementation to create a message that is a response to a request. * * @author Scott.Stark@jboss.org * @version $Revision: 1.1.8.2 $ */ public abstract class MessageFactory { private static final String DEFAULT_MSG_FACTORY = "org.jboss.axis.soap.MessageFactoryImpl"; public MessageFactory() { } /** Creates a new MessageFactory object that is an instance of the default implementation. */ public static MessageFactory newInstance() throws SOAPException { MessageFactory factory = null; String factoryName = null; try { factoryName = System.getProperty("javax.xml.soap.MessageFactory", DEFAULT_MSG_FACTORY); ClassLoader loader = Thread.currentThread().getContextClassLoader(); Class factoryClass = loader.loadClass(factoryName); factory = (MessageFactory)factoryClass.newInstance(); } catch (Throwable t) { throw new SOAPException("Failed to create MessageFactory: " + factoryName, t); } return factory; } /** * Creates a new SOAPMessage object with the default SOAPPart, SOAPEnvelope, SOAPBody, and SOAPHeader objects. * Profile-specific message factories can choose to prepopulate the SOAPMessage object with profile-specific headers. * * Content can be added to this message's SOAPPart object, and the message can be sent "as is" when a message * containing only a SOAP part is sufficient. Otherwise, the SOAPMessage object needs to create one or more * AttachmentPart objects and add them to itself. Any content that is not in XML format must be in an AttachmentPart object. * * @return a new SOAPMessage object * @throws SOAPException if a SOAP error occurs */ public abstract SOAPMessage createMessage() throws SOAPException; /** * Internalizes the contents of the given InputStream object into a new SOAPMessage object and returns the SOAPMessage object. * * @param headers the transport-specific headers passed to the message in a transport-independent fashion for creation of the message * @param in the InputStream object that contains the data for a message * @return a new SOAPMessage object containing the data from the given InputStream object * @throws IOException if there is a problem in reading data from the input stream * @throws SOAPException if the message is invalid */ public abstract SOAPMessage createMessage(MimeHeaders headers, InputStream in) throws IOException, SOAPException; }
MessageFactory.java |