WebSphere Application Server Network Deployment, Version 6.0.x   
             オペレーティング・システム: AIX , HP-UX, Linux, Solaris, Windows

             目次と検索結果のパーソナライズ化

Java コード用の XML パーサー

IBM は、XML 構文解析開発リソースを、Xerces パーサー上で動作するように変更しています。 その目的は、Xerces コード・ベースを XML4J および XML4C の 基礎として使用することです。このバージョンの XML4J は、Apache Xerces2 コードベースに基づいています。

1999 年 11 月 9 日、The Apache Software Foundation は、オープン・ ソース Extensible Markup Language (XML) ソリューションを 対象とした xml.apache.org プロジェクトの設立を発表しました。 その発表の中で、IBM は、 同社の XML4J、XML4C、 および LotusXSL テクノロジーを xml.apache.org プロジェクトに提供していることを明らかにしました。 構文解析テクノロジーは Xerces に、 LotusXSL テクノロジーは Xalan に名前変更されました。

XML4J と Xerces の違いは何ですか?

IBM は、xml.apache.org プロジェクトによって行われたテストのほかに、 このバージョンの XML4J をテストしました。 主要な Java アーカイブ (JAR) ファイルの名前は、 xml4j.jar から xmlParserAPIs.jar および xercesImpl.jar に、xml4jSamples.jar から xercesSamples.jar に変更されました。

このバージョンの XML4J では、 前回の主要なリリースから、主要な API の変更が 1 つと、いくつかの比較的マイナーな API の変更が行われています。 その主要なフィーチャーは、多くのバグ修正とパフォーマンスの向上であり、 さらにいくつかのフィーチャーも追加されています。

XML4J 4.2.x は、正式な W3C DOM HTML 勧告 API に同梱されています。 この API に対する主要な変更点は、HTMLOptionElement インターフェースから setSelected が除外されている点です。 XML4J 4.1.x から変更されたこの点についての次善策は、 HTMLOptionElement インターフェースの setAttribute および removeAttribute を使用して、選択された属性を変更することです。

API のどの部分がパブリックで、変更の対象となるものは何ですか?

この質問に答えるには、 以下のような、アプリケーション・プログラム・インターフェース (API) の状況で使用される用語について理解する必要があります。
  • パブリック - この API の標準的なクライアント開発者コード。 この API に関する深刻な問題に対処します。 また、この API の大部分は、 「パブリック」と定義され、World Wide Web Consortium (W3C) 勧告の状況、 または XML コア作業グループと同じような状況になっています。 これらのインターフェースは、それほど変更されることはありません。 W3C 勧告は、仕様が安定しており、 Web インターオペラビリティーに寄与していることを示します。 この勧告は、業界がその採用をサポートしているすべての W3C メンバーによって、検討されています。
  • 実験的 - これらのインターフェースおよびクラスは、 XML コア作業グループからの最新の W3C 仕様および Simple API for XML (SAX) 仕様を反映します。 これらの仕様は完成されていないため、インターフェースは変更される可能性があります。 実験的仕様は、W3C 勧告レベルなどの高度なレベルで採用されるため、 仕様は「パブリック」カテゴリーにアップグレードされます。
  • 内部 - これらのクラスは、パブリックであるか、 または public メソッドを持っていても、Xerces に対して内部的なものと見なされます。 開発者は、 XML パーサーのビルドなどの複雑で固有のニーズがある場合に、 これらのクラスを使用することができます。 ただし、アーキテクチャーは変更の対象です。
次の表は、インターフェースのコンテンツごとの API 状況の要約です。
API 状況 API コンテンツ (パッケージ、インターフェース、クラス、およびメソッド) コメント
パブリック DOM Level 1 インターフェース (org.w3c.dom、org.w3c.dom.html 内にある) および DOM Level 2 (DOM2) インターフェース (org.w3c.dom およびサブパッケージ内にある)

DOM2 インターフェースは、DOM1 と同じインターフェースで、新規メソッドとしてインプリメントされています。

SAX Level 1 インターフェース (org.xml.sax. およびサブパッケージ内にある) および SAX Level 2 (SAX2) インターフェース (org.xml.sax. およびサブパッケージ内にある)

DOM L1、DOM L2、SAX1、および SAX2 インターフェースは安定しています。
実験的 DOM Level 3 (DOM3) および Core DOM Level 3 (DOM3) 抽象スキーマと、ロードおよび保管 (org.apache.xerces.dom3 およびサブパッケージ内にある)。 DOM L3 は作業ドラフト状況にあります。XML4J は 、DOM L3 サポートのサブセットを提供します。
内部 他のすべてのパッケージは、内部的なものです。 内部 Xerces アーキテクチャーは変更される場合があります。

詳しくは、XML4J Information を参照してください。

Apache Open Source プロジェクトとして、Xerces コミュニティーは、 パブリックとして指定した部分だけでなく、API 全体に関する質問およびフィードバックに興味があります。

Xerces API またはコードに関して、特定の質問、パッチ、またはフィードバックをお持ちの場合は、Apache Web サイトを訪問し、メーリング・リストにご登録ください。 基本的な質問または XML4J に関する特定の質問は、 AlphaWorks ディスカッション・フォーラムまでお寄せください。

新規開発を行う場合は、どの API を使用すればよいですか?

新規開発には org.apache.xerces.parsers.* クラスを使用します。 4 つの互換性パーサー・クラスが、以下のクラスに置き換えられました。
org.apache.xerces.parsers.SAXParser 
org.apache.xerces.parsers.DOMParser

検証制御がこのパーサーのフィーチャーになったので、 別々のクラスは必要なくなります。

パーサー・インスタンス化クラスの将来の方向はパーサー・インスタンス化 API で、 これは、現在進められている W3C DOM Level 3 の取り組みの結果となります。

ご使用のコードを確実にできるだけ安定させるため、 可能な場合は必ず、前の表の「パブリック」セクションで指定されたインターフェース (例えば、 DOM1 および SAX1) を使用します。 表を定期的に更新して、「パブリック」状況に指定された新規インターフェースおよびクラス (例えば、 DOM2 および SAX2) を反映してください。

IBM は XML4J に関して追加サポート保証を行っていますか?

IBM は、 XML4J に関する追加サポート保証を行っていません。具体的に言うと 、IBM は、XML4J が Y2K 準拠であることを保証していません。XML4J は、内部日付計算を行いません。

XML4J 4.2.2 パーサーおよび XSLT4J 2.5.4 変換プログラムを使用するための、 アプリケーションのマイグレーション

Java API for XML Processing (JAXP) 仕様は、 javax.xml.parsers API を使用して、SAX または DOM パーサーのプラグ可能メカニズムを定義します。 変換プログラムは、Javax.xml.transform API 経由でプラグ可能です。

バージョン 6.0.x にバンドルされている IBM SDK 1.4.1 には、XML4J 4.2.2 パーサーおよび XSLT4J 2.5.4 変換プログラムが含まれています。アプリケーションで 、JAXP の異なるインプリメンテーションを使用することができます。 このアプリケーションにパーサーと変換プログラムをパッケージします。

アプリケーションを変更して、 以前のバージョンの WebSphere Application Server から、以前のバージョンのパーサーまたは 変換プログラムの API 上の依存関係を取り除くことができます。アプリケーションに JAR ファイルをパッケージします。

いずれの場合も、 アプリケーションまたは Web モジュールには PARENT_LAST にクラス・ローダー代行モードを設定します。

推奨: アプリケーションでは、 パーサーまたは変換プログラム・インプリメンテーション API を直接使用するのではなく JAXP API を使用するようにしてください。

V4.0.x XML アプリケーションまたは V5.x XML アプリケーションをバージョン 6.0.x レベルにマイグレーションするには、 それを再コンパイルする必要があります。




関連タスク
マイグレーション後の WebSphere Application Server の構成
参照トピック    

ご利用条件 | フィードバック

最終更新: Jan 21, 2008 10:13:28 PM EST
http://publib.boulder.ibm.com/infocenter/wasinfo/v6r0/index.jsp?topic=/com.ibm.websphere.nd.doc/info/ae/ae/rins_config3.html