メインコンテンツへジャンプする

JPNICはインターネットの円滑な運営を支えるための組織です

ロゴ:JPNIC

WHOIS 検索 サイト内検索 WHOISとは? JPNIC WHOIS Gateway
WHOIS検索 サイト内検索

mDN Wrapper


概要

Windows で多言語ドメイン名を扱えるようにするためには、 Windows 上のクライアントアプリケーションにおいて、 解決しようとする名前のエンコーディングを、 DNS サーバが受付ける形式のものに変換する必要があります。 これは、Windows 上のアプリケーションが、 きちんと多言語ドメイン名を扱えるようになっていなければならない、 ということであり、本来はそれぞれのプログラムの作成者が行なうべきことです。

しかし、標準が決まっていない現状では、 プログラム作成者にこのような対応を期待するのは無理なので、 既存のアプリケーションを多言語ドメイン名対応させるための トリックが必要になります。 mDNkitに含まれるmdnsproxyサーバはそのための一つの方法です。 ここでは、もう一つの方法、mDN Wrapper を提示します。

Windows において、多くの場合、ドメイン名解決の要求はWINSOCK DLL に渡されます。そこで、WINSOCK DLL を多言語ドメイン名対応のものに置き 換えてやれば、既存のプログラムからでも多言語ドメイン名を使うことがで きるようになります。


セットアップ

注意: もし古いバージョンの mDN Wrapper がすでにインストールされているマシンに 新しいバージョンをインストールする場合には、まず バージョンアップ時の注意をご覧ください。

mDN Wrapper をインストールするには setup.exe を実行します。 セットアッププログラムは次のような処理を行います。

ファイルのインストール
ディレクトリ \Program Files\JPNIC\mDN Wrapper (セットアップで変更可能)以下に、 mDN Wrapper を構成するファイルをコピーします。
レジストリの設定
HKEY_LOCAL_MACHINE\Software\JPNIC\MDN 以下に必要な レジストリキー、レジストリ値を作成、設定します。主なものは次の通りです。
ConfFile REG_SZ
多言語ドメイン名処理に関するパラメータを記述した mDNkit の 設定ファイル mdn.conf のパス名です。 設定ファイルのパス名は 設定プログラムで 変更することができます。
LogFile REG_SZ
ログファイルのパス名です。 これも 設定プログラムで 変更することができます。
Where REG_DWORD
WINSOCK のどの部分で変換を行うかを指定する値です。 設定プログラムで変更することができます。 ただしデフォルト値として適切な値が設定されるので、通常この値を 変更する必要はありません。
PerProg キー
プログラム毎の設定値を格納するためのキーです。 この下に、プログラムの実行モジュール名をキーとして プログラム個別の設定が記録されます。 設定される情報は以下の二つです。
PerProg\プログラム名\Where REG_DWORD 変換位置
PerProg\プログラム名\Encoding REG_SZ エンコーディング名
エンコーディング名は、通常は設定プログラムによって設定されます。 変換位置の指定も、通常は不要です。
アイコンの作成
設定プログラムのアイコンを作成し、 スタートメニューに登録します。 これによって設定プログラムを起動することができます。

アンインストールするには、コントロールパネルの「アプリケーションの追 加と削除」で、「mDN Wrapper」を選択して削除(「追加と削除」ボタン) します。


設定プログラム

設定プログラムは、アプリケーションを特定して mDN Wrapper を適用したり、 適用を解除するためのツールです。

起動すると以下のような画面が表示されます。

Configuration Startup

リストボックスには、その時点で mDN Wrapper が適用されているプログラムが 表示されます。 最初に実行した場合には空になっています。右側のボタンを押すことにより、 操作を行うことができます。

mDN Wrapper の適用

プログラムに mDN Wrapper を適用するには、"Wrap.."ボタンを押します。 "Wrap.."ボタンを押すと以下のようなダイアログが表示されます。

Configuration Wrap

最初に、mDN Wrapper を適用したいプログラムの実行ファイル名を設定します。 直接入力するか、ブラウズボタンでファイルを探してください。

Configuration Browse

次にそのプログラムのローカルエンコーディングを指定します。 通常は「Default」 でかまいません。 プログラムが国際化エンコーディングに従っている場合にのみ 「UTF-8」 を指示します。

Configuration Encoding

最後に "Wrap" ボタンを押せば、そのプログラムに対して 指定されたエンコーディングで mDN Wrapper が適用されます。 適用されたプログラムは、最初のウィンドウのリストボックスに反映されます。

Configuration Wrapped

mDN Wrapper の解除

プログラムに対する mDN Wrapper の適用を解除するには、 リストボックスで解除するプログラムを選択して、 "Unwrap.." ボタンを押します。 以下の確認用のダイアログが表示されますので、 間違いがなければ "Unwrap" ボタンを押してください。

Configuration Unwrap

mDN Wrapper の適用が解除されると、そのプログラムは最初のウィンドウの リストボックスからも削除されます。

Configuration Unwraped

"Unwrap All" ボタンを押すことによって、 現在適用されているすべてのプログラムに対して mDN Wrapper の適用を 解除することもできます。

mDN Wrapper の再適用

mDN Wrapper をバージョンアップした場合には、ラッパー DLL を更新するために、 プログラムをもう一度適用し直す必要があります。 "Rewrap All" ボタンを押すことによって、現在適用されているすべてのプログラム に対して一括して mDN Wrapper を再適用することができます。

ログ設定

"Log.." ボタンを押すことによってログレベルやログファイルを設定することが できます。 このボタンを押すと次のようなダイアログが現れます。

Configuration Log

ログレベルは次の中から選ぶことができます。

None
ログを一切出力しません。これがデフォルトです。
Fatal
致命的エラーのみ出力します。
Error
致命的でないエラーも出力します。
Warning
警告メッセージも出力します。
Info
エラー以外の情報も出力します。
Trace
プログラムのトレース情報も出力します。このレベルを選択すると 大量のログが出力されるので気をつけてください。

なお、このログレベルは MDN ライブラリ が 出力するログに対するものです。mDN Wrapper 自体が出力するログについては ON/OFF 以外のレベルを指定することはできず、None を指定すればオフに、 それ以外のレベルを指定すればオンになります。

ログファイルを指定することも可能です。デフォルトでは mDN Wrapper を インストールしたディレクトリの mdn_wrapper.log になっています。 "Browse.." ボタンを押せばブラウズ用のダイアログを利用して選択することが できます。

また、このダイアログではログファイルの内容を見ることと、ログファイルを 削除することが可能です。それぞれ "View"、"Delete" ボタンを押してください。 "View" ボタンを押すとメモ帳が起動して、ログファイルの内容を表示します。

"OK" ボタンを押すとダイアログの設定が有効になります。設定を変えたくない 場合には "Cancel" ボタンを押してください。

詳細パラメータ設定

"Advanced.." ボタンを押すことにより、次のようなダイアログが表示されます。 これは上級ユーザのためのもので、適切なデフォルトが設定されているので 通常ユーザが変更する必要のないような基本的なパラメータを 変更することができます。

Configuration Advanced

ダイアログ最上部のパネルでプログラムに対する mDN Wrapper の適用モードを 指定することができます。選択できる値とその意味は次の通りです。

Wrap both WINSOCK 1.1 and WINSOCK 2.0
WINSOCK 1.1 と 2.0 の両方の呼び出しについて mDN Wrapper を適用し、 ドメイン名のエンコーディング変換や正規化を行います。 Windows 2000 以外はこのモードで使えば正しく動くはずです。
Wrap only WINSOCK 1.1
WINSOCK 1.1 の呼び出しについては mDN Wrapper を適用しますが、 WINSOCK 2.0 の呼び出しについては適用しません。
Wrap only WINSOCK 2.0
WINSOCK 2.0 の呼び出しについては mDN Wrapper を適用しますが、 WINSOCK 1.1 の呼び出しについては適用しません。
Wrap only WINSOCK 2.0 if it exists. Otherwise wrap only WINSOCK 1.1
WINSOCK 2.0 が存在すれば WINSOCK 2.0 の呼び出しについてのみ mDN Wrapper を適用します。存在しない場合には WINSOCK 1.1 の呼び出しに ついて適用します。 Windows 2000 はこのモードで使えば正しく動くはずです。

通常は、OS に応じて適切な値が自動的に設定されますが、WINSOCK の バージョンによってはその設定では正しく動かず、手動で指定し直さなければ ならないかもしれません。

中段のパネルでは mDNkit の設定ファイル mdn.conf のパス名を 設定することができます。 また、"Edit" ボタンを押すとメモ帳が起動され、ファイルを編集することも可能です。

以上の設定は "OK" ボタンを押すことにより有効になります。設定を変えずに ダイアログを終了したい場合には "Cancel" ボタンを押してください。


制限事項

DLL バージョン

ラッパーDLL は、元のWINSOCK のDLL のバージョンに強く依存します。 これは、非公開のエントリも含めて すべてのエントリを提供する必要があるためです。 このためWINSOCK DLL のバージョンが変わると、 mDN Wrapper が動作しなくなる可能性があります。

今回作成されたmDN Wrapper は、

WinNT4.0 SP6a (WINSOCK 1.1 + 2.0)
Win98 (WINSOCK 1.1 + 2.0)
Win95 OSR2 (WINSOCK 1.1)

で動作を確認しています。ただ、将来にわたって動作する保証はありません。

DNS, WINS, LMHOSTS

Windows では、DNS だけではなく、 WINSやLMHOSTS によってもドメイン名、ホスト名の解決が行なわれます。 mDN Wrapper を使った場合には、ドメイン名の変換が、 これらの方式へのディスパッチを行なう場所よりも上位層で行なわれるので、 これらのすべての方式について、 ドメイン名、ホスト名の変換が行なわれることになります。 このため、Windows が、WINSやLMHOSTS を使っている場合には、 予期しない問題が発生する可能性があります。 これについては、mDN Wrapper を使う場合には、 名前解決にDNS だけを使用することをお勧めします。

ドメイン名以外の名前の解決

WINSOCK 2.0 の名前解決API WSALookupServiceBeginWWSALookupServiceNextWWSALookupServiceEnd、 は、ドメイン名以外でも使用できる、 汎用の名前解決用のAPI として定義されています。 現時点では、これらはもっぱらドメイン名の解決で使用されていますが、 他の名前(例えばサービス名)の解決にも使用できることになっています。

mDN Wrapper は、名前の対象の如何にかかわらず、 名前のエンコーディングを変換してしまうので、 これらのAPI が、ドメイン名以外の解決に使われている場合には、 問題を引き起こす可能性があります。

名前解決API を使わないプログラム

アプリケーションによっては、 ドメイン名の解決にこれらのAPI を使用しないものもあります。 例えば、nslookupは、これらのAPI を使用しないで、 直接DNS サーバと通信してしまいます。 このようなアプリケーションについては、 mDN Wrapper は役に立ちません。

特定WINSOCK DLL にバインドされたアプリケーション

アプリケーションによっては、標準のDLL サーチパスに従わないで、 特定のパスのDLL にバインドされているものがあります。 このようなプログラムについては、標準のインストール/設定では mDN Wrapper を適用しても動作しない場合があります。

WINSOCK DLL と同じフォルダにインストールされたアプリケーション

WINSOCK DLL と同じフォルダ (システムディレクトリ) にインストールされた アプリケーションに対してmDN Wrapperを適用したい場合は、そのプログラムを 別のフォルダにコピーし、コピーしたプログラムに対して mDN Wrapperを適用 すると良いでしょう。

mDN Wrapperをシステムディレクトリにインストールするのは、大変危険です。 場合によっては、システムを再起動不能にしてしまう可能性もあります。

代替手段としてのmdnsproxy

これらの制限事項が問題になる場合には、 代替手段としてmdnsproxyを使うこともできます。 これは、DNS サーバとのトランザクションを中継するので、 上で問題になったようなことを回避することができます。

ただし、mdnsproxyは、ラッパーよりも複雑な設定が必要で、 呼び元のプログラムを特定することもできませんので、 プログラム固有のローカルエンコーディングを取り扱うことはできません。 しかし、上記の制限事項が問題になるようなケースでは、 ラッパーの代わりに使用するといいかもしれません。


バージョンアップ時の注意

古いバージョンの mDN Wrapper がすでにインストールされているマシンに 新しいバージョンをインストールする際には、次のことに気をつけてください。

  • すべてのファイルを再度ラップする
    mDN Wrapper はその動作原理上、mDN Wrapper を適用するプログラムが存在する ディレクトリにDLL をコピーします。 コピーされた DLL は新しいバージョンをインストールしても 更新されないので、そのままでは新しいバージョンが使われません。 このため、新しいバージョンをインストールしたら、設定プログラムを 起動し、"Rewrap All" を実行して、改めて mDN Wrapper を適用し直してください。

このページを評価してください

このWebページは役に立ちましたか?
よろしければ回答の理由をご記入ください

それ以外にも、ページの改良点等がございましたら自由にご記入ください。

回答が必要な場合は、お問い合わせ先をご利用ください。

ロゴ:JPNIC

Copyright© 1996-2024 Japan Network Information Center. All Rights Reserved.