- java.lang.Object
-
- javax.xml.transform.stream.StreamSource
-
- All Implemented Interfaces:
- Source
public class StreamSource extends Object implements Source
Acts as an holder for a transformation Source in the form of a stream of XML markup.
Note: Due to their internal use of either a
Reader
orInputStream
instance,StreamSource
instances may only be used once.
-
-
Field Summary
Fields Modifier and Type Field and Description static String
FEATURE
IfTransformerFactory.getFeature(java.lang.String)
returns true when passed this value as an argument, the Transformer supports Source input of this type.
-
Constructor Summary
Constructors Constructor and Description StreamSource()
Zero-argument default constructor.StreamSource(File f)
Construct a StreamSource from a File.StreamSource(InputStream inputStream)
Construct a StreamSource from a byte stream.StreamSource(InputStream inputStream, String systemId)
Construct a StreamSource from a byte stream.StreamSource(Reader reader)
Construct a StreamSource from a character reader.StreamSource(Reader reader, String systemId)
Construct a StreamSource from a character reader.StreamSource(String systemId)
Construct a StreamSource from a URL.
-
Method Summary
Methods Modifier and Type Method and Description InputStream
getInputStream()
Get the byte stream that was set with setByteStream.String
getPublicId()
Get the public identifier that was set with setPublicId.Reader
getReader()
Get the character stream that was set with setReader.String
getSystemId()
Get the system identifier that was set with setSystemId.void
setInputStream(InputStream inputStream)
Set the byte stream to be used as input.void
setPublicId(String publicId)
Set the public identifier for this Source.void
setReader(Reader reader)
Set the input to be a character reader.void
setSystemId(File f)
Set the system ID from a File reference.void
setSystemId(String systemId)
Set the system identifier for this Source.
-
-
-
Field Detail
-
FEATURE
public static final String FEATURE
IfTransformerFactory.getFeature(java.lang.String)
returns true when passed this value as an argument, the Transformer supports Source input of this type.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
StreamSource
public StreamSource()
Zero-argument default constructor. If this constructor is used, and no Stream source is set using
setInputStream(java.io.InputStream inputStream)
orsetReader(java.io.Reader reader)
, then theTransformer
will create an empty sourceInputStream
usingnew InputStream()
.
-
StreamSource
public StreamSource(InputStream inputStream)
Construct a StreamSource from a byte stream. Normally, a stream should be used rather than a reader, so the XML parser can resolve character encoding specified by the XML declaration.If this constructor is used to process a stylesheet, normally setSystemId should also be called, so that relative URI references can be resolved.
- Parameters:
inputStream
- A valid InputStream reference to an XML stream.
-
StreamSource
public StreamSource(InputStream inputStream, String systemId)
Construct a StreamSource from a byte stream. Normally, a stream should be used rather than a reader, so that the XML parser can resolve character encoding specified by the XML declaration.This constructor allows the systemID to be set in addition to the input stream, which allows relative URIs to be processed.
- Parameters:
inputStream
- A valid InputStream reference to an XML stream.systemId
- Must be a String that conforms to the URI syntax.
-
StreamSource
public StreamSource(Reader reader)
Construct a StreamSource from a character reader. Normally, a stream should be used rather than a reader, so that the XML parser can resolve character encoding specified by the XML declaration. However, in many cases the encoding of the input stream is already resolved, as in the case of reading XML from a StringReader.- Parameters:
reader
- A valid Reader reference to an XML character stream.
-
StreamSource
public StreamSource(Reader reader, String systemId)
Construct a StreamSource from a character reader. Normally, a stream should be used rather than a reader, so that the XML parser may resolve character encoding specified by the XML declaration. However, in many cases the encoding of the input stream is already resolved, as in the case of reading XML from a StringReader.- Parameters:
reader
- A valid Reader reference to an XML character stream.systemId
- Must be a String that conforms to the URI syntax.
-
StreamSource
public StreamSource(String systemId)
Construct a StreamSource from a URL.- Parameters:
systemId
- Must be a String that conforms to the URI syntax.
-
StreamSource
public StreamSource(File f)
Construct a StreamSource from a File.- Parameters:
f
- Must a non-null File reference.
-
-
Method Detail
-
setInputStream
public void setInputStream(InputStream inputStream)
Set the byte stream to be used as input. Normally, a stream should be used rather than a reader, so that the XML parser can resolve character encoding specified by the XML declaration.If this Source object is used to process a stylesheet, normally setSystemId should also be called, so that relative URL references can be resolved.
- Parameters:
inputStream
- A valid InputStream reference to an XML stream.
-
getInputStream
public InputStream getInputStream()
Get the byte stream that was set with setByteStream.- Returns:
- The byte stream that was set with setByteStream, or null if setByteStream or the ByteStream constructor was not called.
-
setReader
public void setReader(Reader reader)
Set the input to be a character reader. Normally, a stream should be used rather than a reader, so that the XML parser can resolve character encoding specified by the XML declaration. However, in many cases the encoding of the input stream is already resolved, as in the case of reading XML from a StringReader.- Parameters:
reader
- A valid Reader reference to an XML CharacterStream.
-
getReader
public Reader getReader()
Get the character stream that was set with setReader.- Returns:
- The character stream that was set with setReader, or null if setReader or the Reader constructor was not called.
-
setPublicId
public void setPublicId(String publicId)
Set the public identifier for this Source.The public identifier is always optional: if the application writer includes one, it will be provided as part of the location information.
- Parameters:
publicId
- The public identifier as a string.
-
getPublicId
public String getPublicId()
Get the public identifier that was set with setPublicId.- Returns:
- The public identifier that was set with setPublicId, or null if setPublicId was not called.
-
setSystemId
public void setSystemId(String systemId)
Set the system identifier for this Source.The system identifier is optional if there is a byte stream or a character stream, but it is still useful to provide one, since the application can use it to resolve relative URIs and can include it in error messages and warnings (the parser will attempt to open a connection to the URI only if there is no byte stream or character stream specified).
- Specified by:
setSystemId
in interfaceSource
- Parameters:
systemId
- The system identifier as a URL string.
-
getSystemId
public String getSystemId()
Get the system identifier that was set with setSystemId.- Specified by:
getSystemId
in interfaceSource
- Returns:
- The system identifier that was set with setSystemId, or null if setSystemId was not called.
-
setSystemId
public void setSystemId(File f)
Set the system ID from a File reference.- Parameters:
f
- Must a non-null File reference.
-
-
Traduction non disponible
Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.
Version en cache
23/01/2025 02:13:52 Cette version de la page est en cache (à la date du 23/01/2025 02:13:52) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.Document créé le 01/09/2006, dernière modification le 04/03/2020
Source du document imprimé : https://www.gaudry.be/java-api-rf-javax/xml/transform/stream/streamsource.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.