Class SaxonDocument
- All Implemented Interfaces:
- XML
Objects of this class are immutable, but NOT thread-safe.
- Since:
- 0.28
- 
Constructor SummaryConstructorsConstructorDescriptionSaxonDocument(byte[] data) Public constructor from XML as byte array.SaxonDocument(File file) Public constructor from XML saved in a filesystem.SaxonDocument(InputStream stream) Public constructor from XML as input stream.SaxonDocument(String text) Public constructor from XML as string text.SaxonDocument(URI uri) Public constructor from XML reached by URI.SaxonDocument(URL url) Public constructor from XML reached by URL.SaxonDocument(Path path) Public constructor from XML saved in a filesystem.SaxonDocument(net.sf.saxon.s9api.XdmNode xml) Public constructor from Saxon XML document node.
- 
Method SummaryModifier and TypeMethodDescriptiondeepCopy()Retrieve a deep copy of the DOM node, represented by this wrapper.inner()Retrieve DOM node, represented by this wrapper.merge(NamespaceContext context) Append this namespace context to the existing one.node()Deprecated.Retrieve DOM nodes from the XML response.registerNs(String prefix, Object uri) Register additional namespace prefix for XPath.validate()Validate this XML against the XSD schema inside it.Validate this XML against the provided XSD schema.Find and return text elements or attributes matched by XPath address.
- 
Constructor Details- 
SaxonDocumentPublic constructor from XML as string text.- Parameters:
- text- XML document body.
- Since:
- 0.28.0
 
- 
SaxonDocumentpublic SaxonDocument(byte[] data) Public constructor from XML as byte array.- Parameters:
- data- XML document body as byte array.
- Since:
- 0.28.1
 
- 
SaxonDocumentPublic constructor from XML saved in a filesystem.- Parameters:
- path- Path to XML file in a filesystem.
- Since:
- 0.28.1
 
- 
SaxonDocumentPublic constructor from XML saved in a filesystem.- Parameters:
- file- XML file in a filesystem.
- Since:
- 0.28.1
 
- 
SaxonDocumentPublic constructor from XML reached by URL.- Parameters:
- url- URL of XML document.
- Throws:
- IOException- If fails.
- Since:
- 0.28.1
 
- 
SaxonDocumentPublic constructor from XML reached by URI.- Parameters:
- uri- URI of XML document.
- Throws:
- IOException- If fails.
- Since:
- 0.28.1
 
- 
SaxonDocumentPublic constructor from XML as input stream.- Parameters:
- stream- Input stream with XML document.
- Since:
- 0.28.1
 
- 
SaxonDocumentpublic SaxonDocument(net.sf.saxon.s9api.XdmNode xml) Public constructor from Saxon XML document node.- Parameters:
- xml- Saxon XML document node.
- Since:
- 0.28.0
 
 
- 
- 
Method Details- 
xpathDescription copied from interface:XMLFind and return text elements or attributes matched by XPath address.The XPath query should point to text elements or attributes in the XML document. If any nodes of different types (elements, comments, etc.) are found in result node list - a RuntimeExceptionwill be thrown.Alternatively, the XPath query can be a function or expression that returns a single value instead of pointing to a set of nodes. In this case, the result will be a List containing a single String, the content of which is the result of the evaluation. If the expression result is not a String, it will be converted to a String representation and returned as such. For example, a document containing three <a> elements, the input query "count(//a)", will return a singleton List with a single string value "3". This is a convenient method, which is used (according to our experience) in 95% of all cases. Usually you don't need to get anything else but a text value of some node or an attribute. And in most cases you are interested to get just the first value (use xpath(..).get(0)). But when/if you need to get more than just a plain text - useXML.nodes(String).The Listreturned will throwIndexOutOfBoundsExceptionif you try to access a node which wasn't found by this XPath query.An IllegalArgumentExceptionis thrown if the parameter passed is not a valid XPath expression.
- 
nodesDescription copied from interface:XMLRetrieve DOM nodes from the XML response.The Listreturned will throwIndexOutOfBoundsExceptionif you try to access a node which wasn't found by this XPath query.An IllegalArgumentExceptionis thrown if the parameter passed is not a valid XPath expression.
- 
registerNsDescription copied from interface:XMLRegister additional namespace prefix for XPath.For example: String name = new XMLDocument("...") .registerNs("ns1", "http://example.com") .registerNs("foo", "http://example.com/foo") .xpath("/ns1:root/foo:name/text()") .get(0);A number of standard namespaces are registered by default in instances of XML. Their full list is in XMLDocument(String).If a namespace prefix is already registered an IllegalArgumentExceptionwill be thrown.- Specified by:
- registerNsin interface- XML
- Parameters:
- prefix- The XPath prefix to register
- uri- Namespace URI
- Returns:
- A new XML document, with this additional namespace registered
 
- 
mergeDescription copied from interface:XMLAppend this namespace context to the existing one.The existing context (inside this object) and the new one provided will be merged together. The existing context will have higher priority. 
- 
nodeDeprecated.Useinner()ordeepCopy()instead.Retrieve DOM node, represented by this wrapper. This method works exactly the same asdeepCopy().
- 
innerDescription copied from interface:XMLRetrieve DOM node, represented by this wrapper. Pay attention that this method returns inner node, not a deep copy. It means that any changes to the returned node will affect the original XML.
- 
deepCopyDescription copied from interface:XMLRetrieve a deep copy of the DOM node, represented by this wrapper. Might be expensive in terms of performance.
- 
validateDescription copied from interface:XMLValidate this XML against the XSD schema inside it.
- 
validateDescription copied from interface:XMLValidate this XML against the provided XSD schema.
 
- 
inner()ordeepCopy()instead.