XMLReader
implementation class. In JAXP 1.0, this class wrapped the
Parser
interface, however this interface was
replaced by the XMLReader
. For ease
of transition, this class continues to support the same name
and interface as well as supporting new methods.
An instance of this class can be obtained from the
SAXParserFactory.newSAXParser()
method.
Once an instance of this class is obtained, XML can be parsed from
a variety of input sources. These input sources are InputStreams,
Files, URLs, and SAX InputSources.This static method creates a new factory instance based on a system property setting or uses the platform default if no property has been defined.
The system property that controls which Factory implementation
to create is named "javax.xml.parsers.SAXParserFactory"
.
This property names a class that is a concrete subclass of this
abstract class. If no property is defined, a platform default
will be used.
HandlerBase
or the
DefaultHandler
are called.
Implementors of this class which wrap an underlying implementation
can consider using the ParserAdapter
class to initially adapt their SAX1 implementation to work under
this revised class.
- Since:
- 1.4
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
Protected constructor to prevent instantiation. -
Method Summary
Modifier and TypeMethodDescriptionabstract Parser
Returns the SAX parser that is encapsulated by the implementation of this class.abstract Object
getProperty
(String name) Returns the particular property requested for in the underlying implementation ofXMLReader
.Get a reference to theSchema
being used by the XML processor.abstract XMLReader
Returns theXMLReader
that is encapsulated by the implementation of this class.abstract boolean
Indicates whether or not this parser is configured to understand namespaces.abstract boolean
Indicates whether or not this parser is configured to validate XML documents.boolean
Get the XInclude processing mode for this parser.void
parse
(File f, HandlerBase hb) Parse the content of the file specified as XML using the specifiedHandlerBase
.void
parse
(File f, DefaultHandler dh) Parse the content of the file specified as XML using the specifiedDefaultHandler
.void
parse
(InputStream is, HandlerBase hb) Parse the content of the givenInputStream
instance as XML using the specifiedHandlerBase
.void
parse
(InputStream is, HandlerBase hb, String systemId) Parse the content of the givenInputStream
instance as XML using the specifiedHandlerBase
.void
parse
(InputStream is, DefaultHandler dh) Parse the content of the givenInputStream
instance as XML using the specifiedDefaultHandler
.void
parse
(InputStream is, DefaultHandler dh, String systemId) Parse the content of the givenInputStream
instance as XML using the specifiedDefaultHandler
.void
parse
(String uri, HandlerBase hb) Parse the content described by the giving Uniform Resource Identifier (URI) as XML using the specifiedHandlerBase
.void
parse
(String uri, DefaultHandler dh) Parse the content described by the giving Uniform Resource Identifier (URI) as XML using the specifiedDefaultHandler
.void
parse
(InputSource is, HandlerBase hb) Parse the content givenInputSource
as XML using the specifiedHandlerBase
.void
parse
(InputSource is, DefaultHandler dh) Parse the content givenInputSource
as XML using the specifiedDefaultHandler
.void
reset()
Reset thisSAXParser
to its original configuration.abstract void
setProperty
(String name, Object value) Sets the particular property in the underlying implementation ofXMLReader
.
-
Constructor Details
-
SAXParser
protected SAXParser()Protected constructor to prevent instantiation. Use
SAXParserFactory.newSAXParser()
.
-
-
Method Details
-
reset
public void reset()Reset this
SAXParser
to its original configuration.SAXParser
is reset to the same state as when it was created withSAXParserFactory.newSAXParser()
.reset()
is designed to allow the reuse of existingSAXParser
s thus saving resources associated with the creation of newSAXParser
s.The reset
SAXParser
is not guaranteed to have the sameSchema
Object
, e.g.Object.equals(Object obj)
. It is guaranteed to have a functionally equalSchema
.- Throws:
UnsupportedOperationException
- When Implementations do not override this method- Since:
- 1.5
-
parse
Parse the content of the given
InputStream
instance as XML using the specifiedHandlerBase
. Use of the DefaultHandler version of this method is recommended as the HandlerBase class has been deprecated in SAX 2.0.- Parameters:
is
- InputStream containing the content to be parsed.hb
- The SAX HandlerBase to use.- Throws:
IllegalArgumentException
- If the given InputStream is null.SAXException
- If parse produces a SAX error.IOException
- If an IO error occurs interacting with theInputStream
.- See Also:
-
parse
Parse the content of the given
InputStream
instance as XML using the specifiedHandlerBase
. Use of the DefaultHandler version of this method is recommended as the HandlerBase class has been deprecated in SAX 2.0.- Parameters:
is
- InputStream containing the content to be parsed.hb
- The SAX HandlerBase to use.systemId
- The systemId which is needed for resolving relative URIs.- Throws:
IllegalArgumentException
- If the givenInputStream
isnull
.IOException
- If any IO error occurs interacting with theInputStream
.SAXException
- If any SAX errors occur during processing.- See Also:
-
parse
Parse the content of the givenInputStream
instance as XML using the specifiedDefaultHandler
.- Parameters:
is
- InputStream containing the content to be parsed.dh
- The SAX DefaultHandler to use.- Throws:
IllegalArgumentException
- If the given InputStream is null.IOException
- If any IO errors occur.SAXException
- If any SAX errors occur during processing.- See Also:
-
parse
public void parse(InputStream is, DefaultHandler dh, String systemId) throws SAXException, IOException Parse the content of the givenInputStream
instance as XML using the specified
-