- 
 public interface XMLStreamWriterThe XMLStreamWriter interface specifies how to write XML. The XMLStreamWriter does not perform well formedness checking on its input. However the writeCharacters method is required to escape &, < and > For attribute values the writeAttribute method will escape the above characters plus " to ensure that all character content and attribute values are well formed. Each NAMESPACE and ATTRIBUTE must be individually written.
 Notes:XML Namespaces, javax.xml.stream.isRepairingNamespacesand write method behaviourMethod isRepairingNamespaces== trueisRepairingNamespaces== falsenamespaceURI bound namespaceURI unbound namespaceURI bound namespaceURI unbound writeAttribute(namespaceURI, localName, value)prefix:localName="value" [1] xmlns:{generated}="namespaceURI" {generated}:localName="value" prefix:localName="value" [1] XMLStreamExceptionwriteAttribute(prefix, namespaceURI, localName, value)bound to same prefix: 
 prefix:localName="value" [1]
 
 bound to different prefix:
 xmlns:{generated}="namespaceURI" {generated}:localName="value"xmlns:prefix="namespaceURI" prefix:localName="value" [3] bound to same prefix: 
 prefix:localName="value" [1][2]
 
 bound to different prefix:
 XMLStreamException[2]xmlns:prefix="namespaceURI" prefix:localName="value" [2][5] writeStartElement(namespaceURI, localName)
 
 writeEmptyElement(namespaceURI, localName)<prefix:localName>[1]<{generated}:localName xmlns:{generated}="namespaceURI">prefix:localName>[1]XMLStreamExceptionwriteStartElement(prefix, localName, namespaceURI)
 
 writeEmptyElement(prefix, localName, namespaceURI)bound to same prefix: 
 <prefix:localName>[1]
 
 bound to different prefix:
 <{generated}:localName xmlns:{generated}="namespaceURI"><prefix:localName xmlns:prefix="namespaceURI">[4]bound to same prefix: 
 <prefix:localName>[1]
 
 bound to different prefix:
 XMLStreamException<prefix:localName>- [1] if namespaceURI == default Namespace URI, then no prefix is written
- [2] if prefix == "" || null && namespaceURI == "", then no prefix or Namespace declaration is generated or written
- [3] if prefix == "" || null, then a prefix is randomly generated
- [4] if prefix == "" || null, then it is treated as the default Namespace and no prefix is generated or written, an xmlns declaration is generated and written if the namespaceURI is unbound
- [5] if prefix == "" || null, then it is treated as an invalid attempt to define the default Namespace and an XMLStreamException is thrown
 - Since:
- 1.6
- See Also:
- XMLOutputFactory,- XMLStreamReader
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description voidclose()Close this writer and free any resources associated with the writer.voidflush()Write any cached data to the underlying output mechanism.NamespaceContextgetNamespaceContext()Returns the current namespace context.StringgetPrefix(String uri)Gets the prefix the uri is bound toObjectgetProperty(String name)Get the value of a feature/property from the underlying implementationvoidsetDefaultNamespace(String uri)Binds a URI to the default namespace This URI is bound in the scope of the current START_ELEMENT / END_ELEMENT pair.voidsetNamespaceContext(NamespaceContext context)Sets the current namespace context for prefix and uri bindings.voidsetPrefix(String prefix, String uri)Sets the prefix the uri is bound to.voidwriteAttribute(String localName, String value)Writes an attribute to the output stream without a prefix.voidwriteAttribute(String namespaceURI, String localName, String value)Writes an attribute to the output streamvoidwriteAttribute(String prefix, String namespaceURI, String localName, String value)Writes an attribute to the output streamvoidwriteCData(String data)Writes a CData sectionvoidwriteCharacters(char[] text, int start, int len)Write text to the outputvoidwriteCharacters(String text)Write text to the outputvoidwriteComment(String data)Writes an xml comment with the data enclosedvoidwriteDefaultNamespace(String namespaceURI)Writes the default namespace to the streamvoidwriteDTD(String dtd)Write a DTD section.voidwriteEmptyElement(String localName)Writes an empty element tag to the outputvoidwriteEmptyElement(String namespaceURI, String localName)Writes an empty element tag to the outputvoidwriteEmptyElement(String prefix, String localName, String namespaceURI)Writes an empty element tag to the outputvoidwriteEndDocument()Closes any start tags and writes corresponding end tags.voidwriteEndElement()Writes an end tag to the output relying on the internal state of the writer to determine the prefix and local name of the event.voidwriteEntityRef(String name)Writes an entity referencevoidwriteNamespace(String prefix, String namespaceURI)Writes a namespace to the output stream If the prefix argument to this method is the empty string, "xmlns", or null this method will delegate to writeDefaultNamespacevoidwriteProcessingInstruction(String target)Writes a processing instructionvoidwriteProcessingInstruction(String target, String data)Writes a processing instructionvoidwriteStartDocument()Write the XML Declaration.voidwriteStartDocument(String version)Write the XML Declaration.voidwriteStartDocument(String encoding, String version)Write the XML Declaration.voidwriteStartElement(String localName)Writes a start tag to the output.voidwriteStartElement(String namespaceURI, String localName)Writes a start tag to the outputvoidwriteStartElement(String prefix, String localName, String namespaceURI)Writes a start tag to the output
 
- 
- 
- 
Method Detail- 
writeStartElementvoid writeStartElement(String localName) throws XMLStreamException Writes a start tag to the output. All writeStartElement methods open a new scope in the internal namespace context. Writing the corresponding EndElement causes the scope to be closed.- Parameters:
- localName- local name of the tag, may not be null
- Throws:
- XMLStreamException
 
 - 
writeStartElementvoid writeStartElement(String namespaceURI, String localName) throws XMLStreamException Writes a start tag to the output- Parameters:
- namespaceURI- the namespaceURI of the prefix to use, may not be null
- localName- local name of the tag, may not be null
- Throws:
- XMLStreamException- if the namespace URI has not been bound to a prefix and javax.xml.stream.isRepairingNamespaces has not been set to true
 
 - 
writeStartElementvoid writeStartElement(String prefix, String localName, String namespaceURI) throws XMLStreamException Writes a start tag to the output- Parameters:
- localName- local name of the tag, may not be null
- prefix- the prefix of the tag, may not be null
- namespaceURI- the uri to bind the prefix to, may not be null
- Throws:
- XMLStreamException
 
 - 
writeEmptyElementvoid writeEmptyElement(String namespaceURI, String localName) throws XMLStreamException Writes an empty element tag to the output- Parameters:
- namespaceURI- the uri to bind the tag to, may not be null
- localName- local name of the tag, may not be null
- Throws:
- XMLStreamException- if the namespace URI has not been bound to a prefix and javax.xml.stream.isRepairingNamespaces has not been set to true
 
 - 
writeEmptyElementvoid writeEmptyElement(String prefix, String localName, String namespaceURI) throws XMLStreamException Writes an empty element tag to the output- Parameters:
- prefix- the prefix of the tag, may not be null
- localName- local name of the tag, may not be null
- namespaceURI- the uri to bind the tag to, may not be null
- Throws:
- XMLStreamException
 
 - 
writeEmptyElementvoid writeEmptyElement(String localName) throws XMLStreamException Writes an empty element tag to the output- Parameters:
- localName- local name of the tag, may not be null
- Throws:
- XMLStreamException
 
 - 
writeEndElementvoid writeEndElement() throws XMLStreamExceptionWrites an end tag to the output relying on the internal state of the writer to determine the prefix and local name of the event.- Throws:
- XMLStreamException
 
 - 
writeEndDocumentvoid writeEndDocument() throws XMLStreamExceptionCloses any start tags and writes corresponding end tags.- Throws:
- XMLStreamException
 
 - 
closevoid close() throws XMLStreamExceptionClose this writer and free any resources associated with the writer. This must not close the underlying output stream.- Throws:
- XMLStreamException
 
 - 
flushvoid flush() throws XMLStreamExceptionWrite any cached data to the underlying output mechanism.- Throws:
- XMLStreamException
 
 - 
writeAttributevoid writeAttribute(String localName, String value) throws XMLStreamException Writes an attribute to the output stream without a prefix.- Parameters:
- localName- the local name of the attribute
- value- the value of the attribute
- Throws:
- IllegalStateException- if the current state does not allow Attribute writing
- XMLStreamException
 
 - 
writeAttributevoid writeAttribute(String prefix, String namespaceURI, String localName, String value) throws XMLStreamException Writes an attribute to the output stream- Parameters:
- prefix- the prefix for this attribute
- namespaceURI- the uri of the prefix for this attribute
- localName- the local name of the attribute
- value- the value of the attribute
- Throws:
- IllegalStateException- if the current state does not allow Attribute writing
- XMLStreamException- if the namespace URI has not been bound to a prefix and javax.xml.stream.isRepairingNamespaces has not been set to true
 
 - 
writeAttributevoid writeAttribute(String namespaceURI, String localName, String value) throws XMLStreamException Writes an attribute to the output stream- Parameters:
- namespaceURI- the uri of the prefix for this attribute
- localName- the local name of the attribute
- value- the value of the attribute
- Throws:
- IllegalStateException- if the current state does not allow Attribute writing
- XMLStreamException- if the namespace URI has not been bound to a prefix and javax.xml.stream.isRepairingNamespaces has not been set to true
 
 - 
writeNamespacevoid writeNamespace(String prefix, String namespaceURI) throws XMLStreamException Writes a namespace to the output stream If the prefix argument to this method is the empty string, "xmlns", or null this method will delegate to writeDefaultNamespace- Parameters:
- prefix- the prefix to bind this namespace to
- namespaceURI- the uri to bind the prefix to
- Throws:
- IllegalStateException- if the current state does not allow Namespace writing
- XMLStreamException
 
 - 
writeDefaultNamespacevoid writeDefaultNamespace(String namespaceURI) throws XMLStreamException Writes the default namespace to the stream- Parameters:
- namespaceURI- the uri to bind the default namespace to
- Throws:
- IllegalStateException- if the current state does not allow Namespace writing
- XMLStreamException
 
 - 
writeCommentvoid writeComment(String data) throws XMLStreamException Writes an xml comment with the data enclosed- Parameters:
- data- the data contained in the comment, may be null
- Throws:
- XMLStreamException
 
 - 
writeProcessingInstructionvoid writeProcessingInstruction(String target) throws XMLStreamException Writes a processing instruction- Parameters:
- target- the target of the processing instruction, may not be null
- Throws:
- XMLStreamException
 
 - 
writeProcessingInstructionvoid writeProcessingInstruction(String target, String data) throws XMLStreamException Writes a processing instruction- Parameters:
- target- the target of the processing instruction, may not be null
- data- the data contained in the processing instruction, may not be null
- Throws:
- XMLStreamException
 
 - 
writeCDatavoid writeCData(String data) throws XMLStreamException Writes a CData section- Parameters:
- data- the data contained in the CData Section, may not be null
- Throws:
- XMLStreamException
 
 - 
writeDTDvoid writeDTD(String dtd) throws XMLStreamException Write a DTD section. This string represents the entire doctypedecl production from the XML 1.0 specification.- Parameters:
- dtd- the DTD to be written
- Throws:
- XMLStreamException
 
 - 
writeEntityRefvoid writeEntityRef(String name) throws XMLStreamException Writes an entity reference- Parameters:
- name- the name of the entity
- Throws:
- XMLStreamException
 
 - 
writeStartDocumentvoid writeStartDocument() throws XMLStreamExceptionWrite the XML Declaration. Defaults the XML version to 1.0, and the encoding to utf-8- Throws:
- XMLStreamException
 
 - 
writeStartDocumentvoid writeStartDocument(String version) throws XMLStreamException Write the XML Declaration. Defaults the XML version to 1.0- Parameters:
- version- version of the xml document
- Throws:
- XMLStreamException
 
 - 
writeStartDocumentvoid writeStartDocument(String encoding, String version) throws XMLStreamException Write the XML Declaration. Note that the encoding parameter does not set the actual encoding of the underlying output. That must be set when the instance of the XMLStreamWriter is created using the XMLOutputFactory- Parameters:
- encoding- encoding of the xml declaration
- version- version of the xml document
- Throws:
- XMLStreamException- If given encoding does not match encoding of the underlying stream
 
 - 
writeCharactersvoid writeCharacters(String text) throws XMLStreamException Write text to the output- Parameters:
- text- the value to write
- Throws:
- XMLStreamException
 
 - 
writeCharactersvoid writeCharacters(char[] text, int start, int len) throws XMLStreamExceptionWrite text to the output- Parameters:
- text- the value to write
- start- the starting position in the array
- len- the number of characters to write
- Throws:
- XMLStreamException
 
 - 
getPrefixString getPrefix(String uri) throws XMLStreamException Gets the prefix the uri is bound to- Returns:
- the prefix or null
- Throws:
- XMLStreamException
 
 - 
setPrefixvoid setPrefix(String prefix, String uri) throws XMLStreamException Sets the prefix the uri is bound to. This prefix is bound in the scope of the current START_ELEMENT / END_ELEMENT pair. If this method is called before a START_ELEMENT has been written the prefix is bound in the root scope.- Parameters:
- prefix- the prefix to bind to the uri, may not be null
- uri- the uri to bind to the prefix, may be null
- Throws:
- XMLStreamException
 
 - 
setDefaultNamespacevoid setDefaultNamespace(String uri) throws XMLStreamException Binds a URI to the default namespace This URI is bound in the scope of the current START_ELEMENT / END_ELEMENT pair. If this method is called before a START_ELEMENT has been written the uri is bound in the root scope.- Parameters:
- uri- the uri to bind to the default namespace, may be null
- Throws:
- XMLStreamException
 
 - 
setNamespaceContextvoid setNamespaceContext(NamespaceContext context) throws XMLStreamException Sets the current namespace context for prefix and uri bindings. This context becomes the root namespace context for writing and will replace the current root namespace context. Subsequent calls to setPrefix and setDefaultNamespace will bind namespaces using the context passed to the method as the root context for resolving namespaces. This method may only be called once at the start of the document. It does not cause the namespaces to be declared. If a namespace URI to prefix mapping is found in the namespace context it is treated as declared and the prefix may be used by the StreamWriter.- Parameters:
- context- the namespace context to use for this writer, may not be null
- Throws:
- XMLStreamException
 
 - 
getNamespaceContextNamespaceContext getNamespaceContext() Returns the current namespace context.- Returns:
- the current NamespaceContext
 
 - 
getPropertyObject getProperty(String name) throws IllegalArgumentException Get the value of a feature/property from the underlying implementation- Parameters:
- name- The name of the property, may not be null
- Returns:
- The value of the property
- Throws:
- IllegalArgumentException- if the property is not supported
- NullPointerException- if the name is null
 
 
- 
 
-