|
JavaTM 2 Platform Std. Ed. v1.4.0 |
||||||||||
前のクラス 次のクラス | フレームあり フレームなし | ||||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object | +--org.xml.sax.InputSource
XML エンティティの単一の入力ソースです。
このモジュールは、ソースコード、文書ともに公開ドメインに置かれています。したがって、内容に関する保証は一切提供されません。
SAX アプリケーションは、このクラスを利用して入力ソースに関する情報を単一のオブジェクトにカプセル化します。このオブジェクトには、公開識別子、システム識別子、バイトストリーム (エンコーディングが指定されている場合もある)、文字ストリームなどが含まれます。
アプリケーションは、この入力ソースを Parser.parse メソッドの引数として、あるいは EntityResolver.resolveEntity メソッドの戻り値としてパーサに渡します。
SAX パーサは、この InputSource オブジェクトを使って XML 入力の読み込みの方法を決定します。パーサは、文字ストリームが使用できればこれを直接読み込み、使用できなければバイトストリームを使用します。文字ストリームもバイトストリームも使用できない場合は、システム識別子で示されたリソースへの URI 接続を開始しようとします。
InputSource オブジェクトはアプリケーションに所属するため、これを SAX パーサが変更することはできません。ただし、必要に応じてコピーすることは可能です。
Parser.parse(org.xml.sax.InputSource)
,
EntityResolver.resolveEntity(java.lang.String, java.lang.String)
,
InputStream
,
Reader
コンストラクタの概要 | |
InputSource()
デフォルトの引数なしのコンストラクタ |
|
InputSource(InputStream byteStream)
バイトストリームを指定して新しい入力ソースを作成します。 |
|
InputSource(Reader characterStream)
文字ストリームを指定して新しい入力ソースを作成します。 |
|
InputSource(String systemId)
システム識別子を指定して新しい入力ソースを作成します。 |
メソッドの概要 | |
InputStream |
getByteStream()
この入力ソースのバイトストリームを取得します。 |
Reader |
getCharacterStream()
この入力ソースの文字ストリームを取得します。 |
String |
getEncoding()
バイトストリームまたは URI の文字セットを取得します。 |
String |
getPublicId()
この入力ソースの公開識別子を取得します。 |
String |
getSystemId()
この入力ソースのシステム識別子を取得します。 |
void |
setByteStream(InputStream byteStream)
この入力ソースのバイトストリームを設定します。 |
void |
setCharacterStream(Reader characterStream)
この入力ソースの文字ストリームを設定します。 |
void |
setEncoding(String encoding)
文字セットがわかっている場合、これを設定します。 |
void |
setPublicId(String publicId)
この入力ソースの公開識別子を設定します。 |
void |
setSystemId(String systemId)
この入力ソースのシステム識別子を設定します。 |
クラス java.lang.Object から継承したメソッド |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
コンストラクタの詳細 |
public InputSource()
setPublicId(java.lang.String)
,
setSystemId(java.lang.String)
,
setByteStream(java.io.InputStream)
,
setCharacterStream(java.io.Reader)
,
setEncoding(java.lang.String)
public InputSource(String systemId)
setPublicId を使って、アプリケーションに公開識別子を含めることもできます。setEncoding を使って既知の文字セットを指定することもできます。
システム識別子が URL である場合、完全に解決する必要があります。
systemId
- システム識別子 (URI)setPublicId(java.lang.String)
,
setSystemId(java.lang.String)
,
setByteStream(java.io.InputStream)
,
setEncoding(java.lang.String)
,
setCharacterStream(java.io.Reader)
public InputSource(InputStream byteStream)
アプリケーションの作成者は、setSystemId を使って関連 URI のベースを提供することができます。SetPublicId を使ってアプリケーションに公開識別子を含めたり、setEncoding を使ってオブジェクトの文字セットを指定することもできます。
byteStream
- 文書を含む raw バイトストリームsetPublicId(java.lang.String)
,
setSystemId(java.lang.String)
,
setEncoding(java.lang.String)
,
setByteStream(java.io.InputStream)
,
setCharacterStream(java.io.Reader)
public InputSource(Reader characterStream)
アプリケーションの作成者は、setSystemId() を使って、関連 URI を解決するためのベースを提供できます。また、setPublicId を使ってアプリケーションに公開識別子を含めることができます。
バイト順序記号は文字ストリームに含まれません。
setPublicId(java.lang.String)
,
setSystemId(java.lang.String)
,
setByteStream(java.io.InputStream)
,
setCharacterStream(java.io.Reader)
メソッドの詳細 |
public void setPublicId(String publicId)
公開識別子は常にオプションです。アプリケーションに公開識別子を含めたい場合は、位置情報の一部として指定します。
publicId
- 公開識別子を示す文字列getPublicId()
,
Locator.getPublicId()
,
SAXParseException.getPublicId()
public String getPublicId()
setPublicId(java.lang.String)
public void setSystemId(String systemId)
バイトストリームや文字ストリームが存在する場合、システム識別子はオプションです。しかし、アプリケーションにシステム識別子が含まれていれば、関連 URI を解決したりエラーメッセージや警告にこのシステム識別子を含めることができるという利点があります。なお、パーサは、バイトストリームや文字ストリームが指定されていない場合にかぎり URI への接続を開始しようとします。
システム識別子が示すオブジェクトの文字セットがわかっている場合、アプリケーションは setEncoding メソッドを使ってこのエンコーディングを登録できます。
システム ID が URL である場合、完全に解決する必要があります。
systemId
- システム識別子を示す文字列setEncoding(java.lang.String)
,
getSystemId()
,
Locator.getSystemId()
,
SAXParseException.getSystemId()
public String getSystemId()
getEncoding メソッドは、このシステム識別子が示すオブジェクトの文字セットを返します。不明な場合は null を返します。
システム ID が URL である場合、完全に解決されます。
setSystemId(java.lang.String)
,
getEncoding()
public void setByteStream(InputStream byteStream)
SAX パーサは、バイトストリームのほかに文字ストリームが指定されている場合、バイトストリームを無視します。バイトストリームは、URI 接続を開始するより優先的に使用されます。
バイトストリームの文字セットがわかっている場合、アプリケーションは setEncoding メソッドを使ってこのエンコーディングを設定する必要があります。
byteStream
- XML 文書またはその他のエンティティを含むバイトストリームsetEncoding(java.lang.String)
,
getByteStream()
,
getEncoding()
,
InputStream
public InputStream getByteStream()
getEncoding メソッドは、このバイトストリームの文字セットを返します。不明な場合は null を返します。
getEncoding()
,
setByteStream(java.io.InputStream)
public void setEncoding(String encoding)
エンコーディングは、XML エンコーディング宣言 (XML 1.0 勧告のセクション 4.3.3 を参照) の規定に合った文字列でなければなりません。
アプリケーションが文字ストリームを提供する場合、このメソッドには何の効果もありません。
encoding
- 文字セットを説明する文字列setSystemId(java.lang.String)
,
setByteStream(java.io.InputStream)
,
getEncoding()
public String getEncoding()
setByteStream(java.io.InputStream)
,
getSystemId()
,
getByteStream()
public void setCharacterStream(Reader characterStream)
文字ストリームが指定されている場合、SAX パーサはバイトストリームを無視し、また、システム識別子への URI 接続を開始しません。
characterStream
- XML 文書またはその他のエンティティを含む文字ストリームgetCharacterStream()
,
Reader
public Reader getCharacterStream()
setCharacterStream(java.io.Reader)
|
JavaTM 2 Platform Std. Ed. v1.4.0 |
||||||||||
前のクラス 次のクラス | フレームあり フレームなし | ||||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Java、Java 2D、および JDBC は米国ならびにその他の国における米国 Sun Microsystems, Inc. の商標もしくは登録商標です。
Copyright 1993-2002 Sun Microsystems, Inc. 901 San Antonio Road
Palo Alto, California, 94303, U.S.A. All Rights Reserved.