一般的な問題: JAR ファイル内のリソース ファイル (document.xml) を検索/検索する際に、特定の位置が固定されておらず、ファイルの名前も事前に不明です。
状況: 2 つの JavaSE プロジェクトで、両方とも独自の JAR ファイルを作成します。Jar-A
jar内のどこかにxmlドキュメントを保持します(場所は事前にわかりません)。特定の操作(設定情報など)のためにドキュメントの引き渡しJar-B
を依頼したい。JarA
呼び出し元は Jar-B
、リソース/ファイルがどのように呼び出され、その現在の場所がどこにあるかを知りませんJar-A
。
要件:内でリソースの名前を変更したり移動したりできるためJar-B
、リソース/ファイルの固定された場所に依存する必要があり ます。探しているファイルの場所とファイルの名前を尋ねる必要があります。Jar-A
Jar-A
Jar-B
Jar-A
考えられる解決策の方向:META-INF
ディレクトリは常にMANIFETS.MF
キーと値のペアを持つファイルを保持します。したがって、'ResourceLocator' というキーと 'org.my.package.ResourceLocator.class' のような値を保存すると、Jar-B
ロードしてロケーター オブジェクトをインスタンス化できるクラスを見つけることができます。探しているファイルですよね?
resourcelocator を使用して、この方法でより多くの値を検索できます。
内に resourcelocator オブジェクトがあるJar-A
ため、「もの」を参照するためのキーのみを文書化する必要がありますが、実際の実装は外部の世界から分離されています。
これがこの種のルックアップに対処するための良いアプローチであるかどうか疑問に思っていますか? についてはすでに知っていNetbeans Lookup API
ますが、ルックアップにはクラス/インターフェース名が必要です。それは私が今探しているものではありません。
事前に知られていないリソースを検索するときに、 と を分離したままにする方法はJar-A
ありますか?Jar-B
注: これはサービス ローダーやエクスターション メカニズムではありませJar-B
んJar-A
。ここではそうではありません。Jar-A
の存在を知りませんJar-B
。
うまくいけば、誰かがすでにこの「問題」に遭遇しています。あなたのアイデアを共有してください.ありがとう!
JAR 仕様へのリンク:こちら