|
JavaTM Platform Standard Ed. 6 |
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | |||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | |||||||||
XMLReader インタフェースで置き換えられています。
public interface Parser
SAX (Simple API for XML) パーサーの基本インタフェースです。
このモジュールは、ソースコード、文書ともに公開ドメインに置かれています。したがって、内容に関する保証は一切提供されません。詳細については、http://www.saxproject.org を参照してください。
SAX1 のメインのイベント提供インタフェースでしたが、SAX2 で、名前空間機能と高度な構成および拡張機能をサポートする XMLReader に置き換えられました。
すべての SAX1 パーサーは、この基本インタフェースを実装する必要があります。アプリケーションは、さまざまな型のイベントハンドラを登録する際や、URI または文字ストリームから構文解析を開始する際にこのインタフェースを使用します。
すべての SAX1 パーサーは、引数なしのコンストラクタも実装しなければいけません (その他のコンストラクタも使用可能)。
SAX1 パーサーは再利用可能ですが、再入不可能です。つまり最初の構文解析が終了したら、アプリケーションはパーサーオブジェクトを再利用できますが (別の入力ソースでの再利用も可能)、1 回の構文解析で parse() メソッドを繰り返し呼び出すことはできません。
EntityResolver,
DTDHandler,
DocumentHandler,
ErrorHandler,
HandlerBase,
InputSource| メソッドの概要 | |
|---|---|
void |
parse(InputSource source)
推奨されていません。 XML 文書を構文解析します。 |
void |
parse(String systemId)
推奨されていません。 システム識別子 (URI) から XML 文書を構文解析します。 |
void |
setDocumentHandler(DocumentHandler handler)
推奨されていません。 アプリケーションに文書イベントハンドラの登録を許可します。 |
void |
setDTDHandler(DTDHandler handler)
推奨されていません。 アプリケーションに DTD イベントハンドラの登録を許可します。 |
void |
setEntityResolver(EntityResolver resolver)
推奨されていません。 アプリケーションにカスタムエンティティーリゾルバの登録を許可します。 |
void |
setErrorHandler(ErrorHandler handler)
推奨されていません。 アプリケーションにエラーイベントハンドラの登録を許可します。 |
void |
setLocale(Locale locale)
推奨されていません。 アプリケーションにエラーや警告のロケールの要求を許可します。 |
| メソッドの詳細 |
|---|
void setLocale(Locale locale)
throws SAXException
SAX パーサーはエラーおよび警告のローカライズを義務付けられていません。 しかし、要求されたロケールをサポートしていない場合は SAX 例外をスローする必要があります。構文解析中は、アプリケーションからロケールの変更を要求できません。
locale - Java Locale オブジェクト
SAXException - 要求されたロケールがサポートされていない場合、以前の (デフォルトの) ロケールを使って例外をスローSAXException,
SAXParseExceptionvoid setEntityResolver(EntityResolver resolver)
アプリケーションがエンティティーリゾルバを登録しないと、SAX パーサーはシステム識別子を解決し、エンティティー自体への接続を開始します (HandlerBase のデフォルトの動作実装)。
アプリケーションは、構文解析中も新しいエンティティーリゾルバを登録できます。 新しいリゾルバが登録されると、SAX パーサーはただちにこのリゾルバの使用を開始しなければいけません。
resolver - 解決するエンティティーのオブジェクトEntityResolver,
HandlerBasevoid setDTDHandler(DTDHandler handler)
アプリケーションが DTD ハンドラを登録しないと、SAX パーサーが報告するすべての DTD イベントは何の通知もなく無視されます (HandlerBase のデフォルトの動作実装)。
アプリケーションは、構文解析中も新しいハンドラを登録できます。 新しいハンドラが登録されると、SAX パーサーはただちにこのハンドラの使用を開始しなければいけません。
handler - DTD ハンドラDTDHandler,
HandlerBasevoid setDocumentHandler(DocumentHandler handler)
アプリケーションが文書ハンドラを登録しないと、SAX パーサーが報告するすべての文書イベントは何の通知もなく無視されます (HandlerBase のデフォルトの動作実装)。
アプリケーションは、構文解析中も新しいハンドラを登録できます。 新しいハンドラが登録されると、SAX パーサーはただちにこのハンドラの使用を開始しなければいけません。
handler - 文書ハンドラDocumentHandler,
HandlerBasevoid setErrorHandler(ErrorHandler handler)
アプリケーションがエラーイベントハンドラを登録しないと、SAX パーサーが報告するエラーイベントは何の通知もなく無視されます。 ただし、fatalError だけは例外です。 このエラーイベントは SAXException をスローします (HandlerBase のデフォルトの動作実装)。
アプリケーションは、構文解析中も新しいハンドラを登録できます。 新しいハンドラが登録されると、SAX パーサーはただちにこのハンドラの使用を開始しなければいけません。
handler - エラーハンドラErrorHandler,
SAXException,
HandlerBase
void parse(InputSource source)
throws SAXException,
IOException
アプリケーションは、このメソッドを使って、有効な任意の入力ソース (文字ストリーム、バイトストリーム、または URI) から XML 文書の構文解析を開始するように SAX パーサーに指示を送ります。
構文解析中は、アプリケーションからこのメソッドを呼び出すことはできません。 追加する XML 文書がある場合はその 1 つ 1 つに新しい Parser を作成する必要があります。構文解析が完了したら、同じ Parser オブジェクトを再利用できます。 別の入力ソースでの再利用も可能です。
source - XML 文書のトップレベルの 入力ソース
SAXException - SAX 例外。ほかの例外をラップしている可能性がある
IOException - パーサーからの IO 例外。通常、アプリケーションが提供するバイトストリームまたは文字ストリームから発生するInputSource,
parse(java.lang.String),
setEntityResolver(org.xml.sax.EntityResolver),
setDTDHandler(org.xml.sax.DTDHandler),
setDocumentHandler(org.xml.sax.DocumentHandler),
setErrorHandler(org.xml.sax.ErrorHandler)
void parse(String systemId)
throws SAXException,
IOException
このメソッドを使用すれば、システム識別子から簡単に文書を読み取ることができます。次の指定でも同じことができます。
parse(new InputSource(systemId));
システム識別子が URL の場合、アプリケーションはこれをパーサーに渡す前に完全に解決する必要があります。
systemId - システム識別子 (URI)
SAXException - SAX 例外。ほかの例外をラップしている可能性がある
IOException - パーサーからの IO 例外。通常、アプリケーションが提供するバイトストリームまたは文字ストリームから発生するparse(org.xml.sax.InputSource)
|
JavaTM Platform Standard Ed. 6 |
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | |||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | |||||||||
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。