public abstract class ValidatorHandler extends Object implements ContentHandler
ValidatorHandler
オブジェクトはスレッドに対して安全ではなく、再入不可能です。つまり、アプリケーション側で、どのような場合でも1つのValidatorHandler
オブジェクトが複数のスレッドから使用されることがないようにする必要があります。
ValidatorHandler
は、SAXイベントが関連するSchema
に記述された制約セットに従っているかどうかをチェックします。また、デフォルト値の追加などによって、SAXイベントを変更することもできます。
ValidatorHandler
はContentHandler
からの拡張ですが、次のようにベースとなるContentHandler
を洗練させます。
uri
、localName
およびqname
のnull以外の文字列を受け取る必要があります。これは、SAXでnullが許可されている場合でも当てはまります。同様に、ユーザー指定のContentHandler
がこれら3種類のパラメータのnull以外の文字列を受け取ります。
ValidatorHandler
のContentHandler.startPrefixMapping(String,String)
とContentHandler.endPrefixMapping(String)
が正しく呼び出されるようにする必要があります。同様に、ユーザー指定のContentHandler
がstartPrefixMappingおよびendPrefixMappingイベントを受け取ります。ValidatorHandler
が追加の名前空間バインディングを導入する場合、ユーザー指定のContentHandler
は追加のstartPrefixMappingおよびendPrefixMappingイベントを受け取ります。
ContentHandler.startElement(String,String,String,Attributes)
メソッドのAttributes
には、xmlns*属性が含まれる場合と、含まれない場合があります。
startDocumentメソッドが呼び出されるたびにValidatorHandler
は自動的にリセットされます。
この仕様では、ValidatorHandler
のすべての実装で認識する必要がある次の機能を定義しています。
http://xml.org/sax/features/namespace-prefixes
この機能はValidatorHandler
が元のSAXイベント・ストリームに存在しない名前空間バインディングを取得する方法を制御します。この機能がtrueに設定されている場合は、ユーザーのContentHandler
でContentHandler.startElement(String,String,String,Attributes)
コールバックのAttributes
オブジェクトの対応するxmlns*
属性を確認する必要があります。そうでない場合は、ユーザー指定のContentHandler
に渡されるAttributes
にxmlns*
属性が追加されません。
この切替えにかかわらず、名前空間バインディングは、常にユーザー指定のContentHandler
のContentHandler.startPrefixMapping(String,String)
およびContentHandler.endPrefixMapping(String)
メソッドを介してアプリケーションに通知されます。
この機能はValidatorHandler
でSAXイベントを受け取る方法には影響を与えません。SAXイベントの拡張方法を変更するだけです。
この機能はデフォルトでfalse
に設定されます。
修飾子 | コンストラクタと説明 |
---|---|
protected |
ValidatorHandler()
派生クラスのコンストラクタです。
|
修飾子と型 | メソッドと説明 |
---|---|
abstract ContentHandler |
getContentHandler()
拡張された検証結果を受け取る
ContentHandler を取得します。 |
abstract ErrorHandler |
getErrorHandler()
この
ValidatorHandler に設定されている現在のErrorHandler を取得します。 |
boolean |
getFeature(String name)
機能フラグの値を検索します。
|
Object |
getProperty(String name)
プロパティ値を検索します。
|
abstract LSResourceResolver |
getResourceResolver()
この
ValidatorHandler に設定されている現在のLSResourceResolver を取得します。 |
abstract TypeInfoProvider |
getTypeInfoProvider()
この
ValidatorHandler のTypeInfoProvider 実装を取得します。 |
abstract void |
setContentHandler(ContentHandler receiver)
拡張された検証結果を受け取る
ContentHandler を設定します。 |
abstract void |
setErrorHandler(ErrorHandler errorHandler)
検証で発生したエラーを受け取るように
ErrorHandler を設定します。 |
void |
setFeature(String name, boolean value)
この
ValidatorHandler の機能を設定します。 |
void |
setProperty(String name, Object object)
プロパティ値を設定します。
|
abstract void |
setResourceResolver(LSResourceResolver resourceResolver)
検証時のリソース解決をカスタマイズするように
LSResourceResolver を設定します。 |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
characters, endDocument, endElement, endPrefixMapping, ignorableWhitespace, processingInstruction, setDocumentLocator, skippedEntity, startDocument, startElement, startPrefixMapping
protected ValidatorHandler()
派生クラスのコンストラクタです。
このコンストラクタは何も行いません。
派生クラスでは、null
ErrorHandler
およびnull
LSResourceResolver
を持つValidatorHandler
オブジェクトを作成する必要があります。
public abstract void setContentHandler(ContentHandler receiver)
ContentHandler
を設定します。
ContentHandler
が指定されると、ValidatorHandler
はフィルタとして機能し、基本的には入力イベントを指定されたContentHandler
にコピーします。
この実行でValidatorHandler
は、たとえばデフォルトの属性を追加して、イベントを変更することもできます。
ValidatorHandler
は一定量のイベントをバッファに格納することができますが、パーサーがValidatorHandler
を使用できるようにするために、次の要件を満たす必要があります。
ContentHandler.startElement(String, String, String, Attributes)
、ContentHandler.endElement(String, String, String)
、ContentHandler.startDocument()
、またはContentHandler.endDocument()
がValidatorHandler
で呼び出された場合、コールバックが戻る前に、ユーザー指定のContentHandler
の同じメソッドが同じイベントに対して呼び出される必要があります。
ValidatorHandler
は、入力に存在しなかった新しい要素を導入しない可能性があります。
ValidatorHandler
は、入力に存在した属性を削除しない可能性があります。
指定したContentHandler
のコールバック・メソッドが例外をスローした場合、ValidatorHandler
から同じ例外オブジェクトがスローされる必要があります。ErrorHandler
にはそれらの例外を通知しないでください。
このメソッドは検証の途中でも呼び出すことができます。
receiver
- ContentHandler
またはnull値。public abstract ContentHandler getContentHandler()
ContentHandler
を取得します。getContentHandler()
メソッドによって最後に設定されたオブジェクトを返す。または、このValidatorHandler
が作成されてから、そのメソッドが呼び出されていない場合はnullを返す。setContentHandler(ContentHandler)
public abstract void setErrorHandler(ErrorHandler errorHandler)
ErrorHandler
を設定します。
エラー・ハンドラを使用して、検証時のエラー処理プロセスをカスタマイズできます。ErrorHandler
を設定すると、検証で発見されたエラーはまずErrorHandler
に送られます。
エラー・ハンドラはハンドラからSAXException
をスローして、検証をただちに中断することができます。または、エラーを画面に出力したり、ErrorHandler
から正常に戻って検証を続行させたりすることもできます。
Throwable
がErrorHandler
からスローされると、呼出しスタックのルートには同じThrowable
オブジェクトがスローされます。
ValidatorHandler
は、最初にErrorHandler
へ報告してからでないと、SAXException
をスローすることができません。
ErrorHandler
がnullの場合、実装は次のErrorHandler
が設定されたかのように動作します。
class DraconianErrorHandler implementsErrorHandler
{ public void fatalError(SAXParseException
e ) throwsSAXException
{ throw e; } public void error(SAXParseException
e ) throwsSAXException
{ throw e; } public void warning(SAXParseException
e ) throwsSAXException
{ // noop } }
新しいValidatorHandler
オブジェクトが作成されると、最初にこのフィールドはnullに設定されます。
errorHandler
- 設定する新しいエラー・ハンドラ。このパラメータはnullも可。public abstract ErrorHandler getErrorHandler()
ValidatorHandler
に設定されている現在のErrorHandler
を取得します。setErrorHandler(ErrorHandler)
メソッドによって最後に設定されたオブジェクトを返す。または、このValidatorHandler
が作成されてから、そのメソッドが呼び出されていない場合はnullを返す。setErrorHandler(ErrorHandler)
public abstract void setResourceResolver(LSResourceResolver resourceResolver)
LSResourceResolver
を設定します。
ValidatorHandler
は、検証中に外部リソースの場所を確認する必要があるときにLSResourceResolver
を使用しますが、「外部リソースの検索」を厳密に構成するものはスキーマ言語により異なります。
LSResourceResolver
がnullの場合、実装は次のLSResourceResolver
が設定されたかのように動作します。
class DumbLSResourceResolver implementsLSResourceResolver
{ publicLSInput
resolveResource( String publicId, String systemId, String baseURI) { return null; // always return null } }
LSResourceResolver
がRuntimeException
(またはその派生クラスのインスタンス)をスローすると、ValidatorHandler
は構文解析を異常終了し、validate
メソッドの呼出し元は同じRuntimeException
を受け取ります。
新しいValidatorHandler
オブジェクトが作成されると、最初にこのフィールドはnullに設定されます。
resourceResolver
- 設定する新しいリソース・リゾルバ。このパラメータはnullも可。public abstract LSResourceResolver getResourceResolver()
ValidatorHandler
に設定されている現在のLSResourceResolver
を取得します。setResourceResolver(LSResourceResolver)
メソッドによって最後に設定されたオブジェクトを返す。または、このValidatorHandler
が作成されてから、そのメソッドが呼び出されていない場合はnullを返す。setErrorHandler(ErrorHandler)
public abstract TypeInfoProvider getTypeInfoProvider()
ValidatorHandler
のTypeInfoProvider
実装を取得します。
取得したTypeInfoProvider
は構文解析時に照会し、バリデータによって判断された型情報にアクセスできます。
スキーマ言語によっては、型の概念を定義していないものもあり、そうした言語の場合、このメソッドがサポートされないこともあります。しかし、この仕様に準拠するため、W3C XML Schema 1.0の実装ではこの処理をサポートする必要があります。
TypeInfo
の概念をサポートしていない場合はnull。それ以外の場合は、null以外の有効なTypeInfoProvider
。public boolean getFeature(String name) throws SAXNotRecognizedException, SAXNotSupportedException
機能名は完全指定URIです。ValidatorHandler
は機能名を認識できますが、一時的にその値を返すことはできません。機能の値によっては、検証の実行前、実行中、実行後などの特定のコンテキストでしか使用できない場合があります。
独自のURIに基づいて作成された名前を使って、実装者が独自の機能を作成することもできます(推奨)。
name
- 機能名。null以外の完全指定URIで表される。SAXNotRecognizedException
- 機能値を割り当てられない、または取得できない場合。SAXNotSupportedException
- ValidatorHandler
が機能名を認識するだけで、現時点ではその値を判断できない場合。NullPointerException
- name
がnull
である場合。setFeature(String, boolean)
public void setFeature(String name, boolean value) throws SAXNotRecognizedException, SAXNotSupportedException
このValidatorHandler
の機能を設定します。
機能を使用して、ValidatorHandler
がスキーマを解析する方法を制御することができます。機能名は完全指定URIです。SchemaFactory
は機能の値を表示できますが、現在の値を変更することはできません。機能の値によっては、検証の実行前、実行中、実行後などの特定のコンテキストでのみ不変または可変である場合があります。
実装はすべて、XMLConstants.FEATURE_SECURE_PROCESSING
機能をサポートしている必要があります。この機能については次のとおりです。
true
: 実装は実装限界に準拠するXML処理を制限します。例には、エンティティ拡張制限や大容量のリソースを消費するXMLスキーマが含まれます。セキュリティ上の理由からXML処理が制限される場合は、登録済みのErrorHandler.fatalError(SAXParseException exception)
へ呼出しを介して報告されます。setErrorHandler(ErrorHandler errorHandler)
を参照してください。
false
: 実装は実装限界に関係なく、XML仕様に従ってXMLを処理します。
name
- 機能名。null以外の完全指定URIで表される。value
- 機能の要求された値(trueまたはfalse)。SAXNotRecognizedException
- 機能値を割り当てられない、または取得できない場合。SAXNotSupportedException
- ValidatorHandler
が機能名を認識するだけで、要求された値を設定できない場合。NullPointerException
- name
がnull
である場合。getFeature(String)
public void setProperty(String name, Object object) throws SAXNotRecognizedException, SAXNotSupportedException
プロパティ名は完全指定URIです。ValidatorHandler
はプロパティ名を認識できますが、現在の値を変更することはできません。プロパティの値によっては、検証の実行前、実行中、実行後などの特定のコンテキストでのみ不変または可変である場合があります。
ValidatorHandler
は特定のプロパティ名の設定を認識する必要はありません。
name
- プロパティ名。null以外の完全指定URIで表される。object
- 要求されたプロパティ値。SAXNotRecognizedException
- プロパティ値を割り当てられない、または取得できない場合。SAXNotSupportedException
- ValidatorHandler
がプロパティ名を認識するだけで、要求された値を設定できない場合。NullPointerException
- name
がnull
である場合。public Object getProperty(String name) throws SAXNotRecognizedException, SAXNotSupportedException
プロパティ名は完全指定URIです。ValidatorHandler
はプロパティ名を認識できますが、一時的にその値を返すことはできません。プロパティの値によっては、検証の実行前、実行中、実行後などの特定のコンテキストでしか使用できない場合があります。
ValidatorHandler
は特定のプロパティ名を認識する必要はありません。
独自のURIに基づいて作成された名前を使って、実装者が独自のプロパティを作成することもできます(推奨)。
name
- プロパティ名。null以外の完全指定URIで表される。SAXNotRecognizedException
- プロパティ値を割り当てられない、または取得できない場合。SAXNotSupportedException
- XMLReaderがプロパティ名を認識するだけで、現時点ではその値を判断できない場合。NullPointerException
- name
がnull
である場合。setProperty(String, Object)
バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.