Windows で多言語ドメイン名を扱えるようにするためには、 Windows 上のクライアントアプリケーションにおいて、 解決しようとする名前のエンコーディングを、 DNS サーバが受付ける形式のものに変換する必要があります。 これは、Windows 上のアプリケーションが、 きちんと多言語ドメイン名を扱えるようになっていなければならない、 ということであり、本来はそれぞれのプログラムの作成者が行なうべきことです。
しかし、標準が決まっていない現状では、 プログラム作成者にこのような対応を期待するのは無理なので、 既存のアプリケーションを多言語ドメイン名対応させるための トリックが必要になります。 mDNkitに含まれるdnsproxyサーバはそのための一つの方法です。 ここでは、もう一つの方法、mDN Wrapper を提示します。
Windows において、多くの場合、ドメイン名解決の要求はWINSOCK DLL に渡されます。そこで、WINSOCK DLL を多言語ドメイン名対応のものに置き 換えてやれば、既存のプログラムからでも多言語ドメイン名を使うことがで きるようになります。
*注意* もし古いバージョンの mDN Wrapper がすでにインストールされているマシンに 新しいバージョンをインストールする場合には、まず バージョンアップ時の注意をご覧ください。
mDN Wrapper をインストールするには"setup.exe" を実行します。 セットアッププログラムは次のような処理を行います。
PerProg\<progname>\Where | REG_DWORD | 変換位置 |
PerProg\<progname>\Encoding | REG_SZ | エンコーディング名 |
エンコーディング名は通常コンフィギュレーションプログラムによって設定されます。 変換位置の指定は、標準インストールでは不要です。 システムディレクトリへのインストールを行なった場合には、 レジストリエディタで環境に合わせて設定する必要があります。
アンインストールするには、コントロールパネルの「アプリケーションの追 加と削除」で、「mDN Wrapper」を選択して削除(「追加と削除」ボタン) します。
コンフィギュレーションプログラムは、 アプリケーションを特定して mDN Wrapper を適用したり、 適用を解除するためのツールです。
起動すると以下のような画面が表示されます。
リストボックスには、その時点で mDN Wrapper が適用されているプログラムが 表示されます。 最初に実行した場合には空になっています。右側のボタンを押すことにより、 操作を行うことができます。
最初に、mDN Wrapper を適用したいプログラムの実行ファイル名を設定します。 直接入力するか、ブラウズボタンでファイルを探してください。
次にそのプログラムのローカルエンコーディングを指定します。 通常は「Default」 でかまいません。 プログラムが国際化エンコーディングに従っている場合にのみ 「UTF-8」 を指示します。
最後に "Wrap" ボタンを押せば、そのプログラムに対して 指定されたエンコーディングで mDN Wrapper が適用されます。 適用されたプログラムは、最初のウィンドウのリストボックスに反映されます。
mDN Wrapper の適用が解除されると、そのプログラムは最初のウィンドウの リストボックスからも削除されます。
"Unwrap All" ボタンを押すことによって、 現在適用されているすべてのプログラムに対して mDN Wrapper の適用を 解除することもできます。
ログレベルは次の中から選ぶことができます。
ログファイルを指定することも可能です。デフォルトでは mDN Wrapper を インストールしたディレクトリの "mdn_wrapper.log" になっています。 "Browse.." ボタンを押せばブラウズ用のダイアログを利用して選択することが できます。
また、このダイアログではログファイルの内容を見ることと、ログファイルを 削除することが可能です。それぞれ "View"、"Delete" ボタンを押してください。 "View" ボタンを押すとメモ帳が起動して、ログファイルの内容を表示します。
"OK" ボタンを押すとダイアログの設定が有効になります。設定を変えたくない 場合には "Cancel" ボタンを押してください。
ダイアログ最上部のパネルでプログラムに対する mDN Wrapper の適用モードを 指定することができます。選択できる値とその意味は次の通りです。
中段のパネルでは正規化の方式を設定することができます。左側のリストボックスに 使用する正規化の名称が入っており、右側のリストボックスには使用可能な 正規化の名称が入っています。右側のリストボックスから追加したい正規化を 選択し、"Add" ボタンを押すと左側のリストボックスに追加されます。 また、左側のリストボックスで削除したい正規化を選択して "Remove" ボタンを 押せば削除することができます。"Clear" ボタンを押すとすべての正規化が 削除され、また "Reset" ボタンによりデフォルトの設定に戻すことができます。
3段目のパネルでは DNS サーバ側のエンコーディング名を指定することができます。 デフォルトは "RACE" ですが、他のエンコーディングを使用したい場合には ここで指定してください。
以上の設定は "OK" ボタンを押すことにより有効になります。設定を変えずに ダイアログを終了したい場合には "Cancel" ボタンを押してください。
ラッパー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)
Windows では、DNS だけではなく、 WINSやLMHOSTS によってもドメイン名、ホスト名の解決が行なわれます。 mDN Wrapper を使った場合には、ドメイン名の変換が、 これらの方式へのディスパッチを行なう場所よりも上位層で行なわれるので、 これらのすべての方式について、 ドメイン名、ホスト名の変換が行なわれることになります。 このため、Windows が、WINSやLMHOSTS を使っている場合には、 予期しない問題が発生する可能性があります。 これについては、mDN Wrapper を使う場合には、 名前解決にDNS だけを使用することをお勧めします。
WINSOCK 2.0 の名前解決API
は、ドメイン名以外でも使用できる、 汎用の名前解決用のAPI として定義されています。 現時点では、これらはもっぱらドメイン名の解決で使用されていますが、 他の名前(例えばサービス名)の解決にも使用できることになっています。
WSALookupServiceBeginW WSALookupServiceNextW WSALookupServiceEnd
mDN Wrapper は、名前の対象の如何にかかわらず、 名前のエンコーディングを変換してしまうので、 これらのAPI が、ドメイン名以外の解決に使われている場合には、 問題を引き起こす可能性があります。
アプリケーションによっては、 ドメイン名の解決にこれらのAPI を使用しないものもあります。 例えば、'nslookup'は、これらのAPI を使用しないで、 直接DNS サーバと通信してしまいます。 このようなアプリケーションについては、 mDN Wrapper は役に立ちません。
アプリケーションによっては、標準のDLL サーチパスに従わないで、 特定のパスのDLL にバインドされているものがあります。 よく使われるプログラムの中では、Netscape Communicator がそうなっています。 このようなプログラムについては、 標準のインストール/コンフィギュレーションでは mDN Wrapper を適用することは できません。
このようなプログラムについて、どうしても mDN Wrapper を適用する必要があるなら、 システムディレクトリへのインストールを行なうことができます。 ただし、このインストールは大変危険で、 場合によってはシステムを再起動不能にしてしまう可能性もあります。
これらの制限事項が問題になる場合には、 代替手段として'dnsproxy'を使うこともできます。 これは、DNS サーバとのトランザクションを中継するので、 上で問題になったようなことを回避することができます。
ただし、'dnsproxy'は、ラッパーよりも複雑な設定が必要ですし、 また、呼び元のプログラムを特定することができませんので、 プログラム固有のローカルエンコーディングを取り扱うことはできません。 しかし、上記の制限事項が問題になるようなケースでは、 ラッパーの代わりに使用するといいかもしれません。
古いバージョンの mDN Wrapper がすでにインストールされているマシンに 新しいバージョンをインストールする際には、次のことに気をつけてください。