
Apache 2.0でWebDAV
− 変更点と日本語リソース問題の解決 −
宮本 久仁男<miyamotokn@nttdata.co.jp>
NTTデータ システム開発事業本部
基盤システム事業部 第一ソリューション技術担当
2002/6/25
日本語リソース名の取り扱い
■Apache 1.3における日本語リソース名
日本語ファイル名の利用とバージョン管理において、日本語リソース名を使用するに当たっての問題点と、Apache 1.3で日本語リソース名の利用を実現する「mod_encoding」というモジュールを紹介しました。このモジュールを使用することによって、Windows 95/98やWindows 2000などのOSからWebフォルダを使って「日本語」リソース名を扱えるようになります。
■Apache 2.0での問題
mod_encodingはApache 1.3用のモジュールです。モジュールのAPIが大幅に変わったため、そのままだとApache 2.0では使えません。
この問題の解決方法は2つあります。
- Apache 1.3+mod_proxy+mod_encodingをリソース名のエンコーディング変更用のプロキシとして利用する
- Apache 2.0用のmod_encodingを使用する
実は、WebDAV-JP MLにおいて、Apache 2.0+mod_dav環境で日本語リソース名が「化けた」という報告と「化けなかった」という報告を受けていました。筆者の環境で試したところ「化けた」ため、Apache 1.3用のmod_encodingを2.0用に試験的に移植してみたところ、うまく動いたので現在WebDAV Resources JP(http://webdav.todo.gr.jp/)にて公開中です。
今回は、後者のApache 2.0用mod_encodingについて解説します。
■mod_encodingのその後の機能拡張
前述の日本語ファイル名の利用とバージョン管理でmod_encodingを紹介してから、かなりの時間がたっています。当然、その間何もないわけはなく、着実に機能が増えています。以下に簡単にその機能を挙げておきます。
- セキュリティホールのFIX
2002年6月6日にセキュリティホールの存在が確認されました。最新リリースではこのセキュリティホールをFIXしてあります。
- 多様なiconvライブラリの使用/拡張のためのインターフェイス実装
iconv_hookライブラリによってこの機能を実現しています。
- GNU autotools化
configure+makeでコンパイル可能になりました。
- Windows XPの認証ユーザー名表記対応
最後の「Windows XPの認証ユーザー名表記対応」は、Windows XPでユーザー認証を実施した場合、ユーザー名が「サーバのIPアドレス\ユーザー名」という形式になってしまうという問題への対策です。mod_encodingの最新版では、最初の「サーバのIPアドレス\」という文字列を消し、ユーザー名のみを取り出す設定が可能です。
iconvライブラリとGNU autotools化以外は、すべてmod_encodingの機能そのものです。もちろん、最新版のApache 2.0対応版mod_encodingにも取り込んであります。
mod_encodingのインストールと設定
■mod_encodingのApache 2.0対応化
以下の2つのファイルをWebDAV Resources JP(http://webdav.todo.gr.jp/)のdownloadメニューからダウンロードします。mod_encoding.c.apache2.20020611aはmod_encoding.cのApache 2.0用差し替えファイルですが、これはExperimental(試験的実装)の扱いです。
- mod_encoding-20020611a.tar.gz
- mod_encoding.c.apache2.20020611a
次に、mod_encoding-20020611a.tar.gzを展開してmod_encoding.cを差し替えます。
$ gzip -dc mod_encoding-20020611a.tar.gz | tar xvf - |
■iconv_hookライブラリのコンパイルとインストール
iconv_hookライブラリのコンパイルとインストールを行います。iconv_hookライブラリとは、プラットフォームやライブラリによって異なるiconv()の動作について、一部のエンコーディングの扱いを変更するようなライブラリに差し替えたりできる動作フック用のライブラリです。
$ cd mod_encoding-20020611a/lib |
この作業が正常に終わると、libiconv_hook.so(iconv_hookライブラリ)が/usr/local/lib配下にインストールされます。
■mod_encodingのコンパイルとインストール
$ cd .. |
この作業が正常に終わると、mod_encoding.soライブラリが/usr/local/apache2/modules下にインストールされます。
■トラブルシューティング
ここまでで、iconv_hookライブラリとmod_encoding.soがインストールされていると思いますが、mod_encodingのインストール時に「mod_encoding.soファイルがない」と怒られるケースがあります。
この原因が、/usr/local/apache2/buildにあるlibtoolスクリプトの内容が一部不正な状態になっているため、libtoolを使っても.soファイルが作成できないことにあるというところまでは突き止めています。そこで、2つの解決方法を提示しておきます。
●libtoolの内容を編集して直す
筆者が.soの生成に失敗した際、/usr/local/apache2/build/libtoolは以下のように記述されていました。
host_alias= |
この部分を、
host_alias=i686-pc-linux-gnu |
のように修正します。ただし、これだけではmake installしてもmod_encoding.soを探してもらえないので、
$ cp .libs/mod_encoding.so /usr/local/apache2/modules |
などとして.libsに作成されたmod_encoding.soを手動で/usr/local/apache2/modulesにコピーします。
●libtoolを使用せず、gccで最終的な.soファイルを作成する
gccを使って、直接.soファイルを作成する方法もあります。
$ gcc -shared -o mod_encoding.so mod_encoding.o -Wc,-Wall
-L/usr/local/lib -Llib -liconv_hook |
などというようなコマンドラインを実行し、mod_encoding.soを作成します。こうして作成したmod_encoding.soは、mod_*なモジュールが格納されるディレクトリにコピーしてやることで使用可能になります。
■mod_encodingの設定と使用
mod_encodingがインストールできたら、実際に動かしてみましょう。httpd.confの適切な個所に、
LoadModule encoding_module modules/mod_encoding.so |
と記述することでmod_encodingが動作します。実際の動作は、日本語ファイル名の利用とバージョン管理で紹介しているのと何ら変わることはありません。
mod_davによるperchild MPMの活用
冒頭に書いた「不安定になってしまったが、安定すればWebDAVを利用するに当たって非常に有用なもの」が「perchild MPM」です。
perchild MPMは不幸にして動作が安定せず、Apache 2.0.36のリリースでexperimentalになってしまいましたが、Apache 2.0の新機能とその実力に書かれている以上の拡張が行われています。具体的には、
起動時に生成するサーバプロセスに、個別のユーザー権限を割り当て可能
という機能が付加されています。この機能の概念を図2に示します(注)。
| 注:perchild MPMは、最初に生成した数以上のプロセスを生成しません。そのためにこうした動作が容易になったのだろうと思います。いまだに安定していませんが……。 |
![]() |
| 図2 ユーザー権限を分けられるため、複数のApache(httpd)を起動する必要がない |
この機能が実現すれば、図2のようにhttpdのユーザー権限とは異なるプライベートな(例えばユーザーwakatono権限やユーザーkmiya権限などを持った)VirtualHostを立ち上げることが可能になります。この場合、suexecのようなwrapperを持つ必要がなく、より自由度が上がります。
本格的なアクセスコントロールを実現するためには、ACLのRFC化と実装を待つ必要がありますが、ファイルを読み書きするためのプライベートストレージとしては十分な機能といえるでしょう。
|
2/2
|
|
||||
|
||||
| Linux Square全記事インデックス |
| Linux Squareフォーラム WebDAV関連記事 |
| 特集:次世代プロトコルWebDAVの可能性[前編] 技術仕様徹底解説 将来、SambaやCVSを不要にする可能性を秘めた「WebDAV」。このプロトコルの仕様から実用化までを徹底解説。今回は、技術仕様を明らかにする |
|
| 特集:次世代プロトコルWebDAVの可能性[中編] WebDAVクライアント/サーバ環境の構築 WebDAVの実装はすでに存在する。LinuxによるWebDAVサーバの構築とクライアントの整備を行い、実際に使ってみよう |
|
| 特集:次世代プロトコルWebDAVの可能性[後編] 日本語ファイル名の利用とバージョン管理 日本語ファイル名を扱えるようにするほか、WebDAVの「V」を司るバージョン管理機能を実現。WebDAV解説完結編! |
|
| 特集:WebDAV時代のセキュリティ対策[前編] WebDAVのメソッドは便利な反面、セキュリティホールとなり得る。しかし、適切な対策を講じることでメソッドの危険性は取り除くことができる |
|
| 特集:WebDAV時代のセキュリティ対策[後編] WebDAVの使用に際し、包括的な対策を行っておくのも重要である。何をどのように設定すればよいのかをここで明らかにする |
|
| 特集:Apache
2.0でWebDAV Apache 2.0の正式リリースでWebDAVも新たな段階に入った。一方で、1.3時代のmod_encodingがうまく機能しないという問題も浮上した |
|
| 特集:Subversionによるバージョン管理 DeltaVがRFCとしてリリースされ、WebDAVのバージョン管理機能も足元か固まった。DeltaVの実装である「Subversion」を導入しよう |
|
| Linux Squareフォーラム全記事インデックス |
|
TechTargetジャパン
- 新しい記事も入っていて安心しました (2012/2/7)
Linux Squareのアクセスランキングを公開します。定番の記事ばかりでなく、連載中の記事もよろしくお願いいたします - エラーメッセージをどう扱うか? (2012/2/2)
今回は、スクリプト実行時にエラーが発生したことを知らせるメッセージの扱い方を説明します - ファイルのアップロードを制限する (2012/1/30)
HTTPクライアントがアップロードしてくるファイルの扱いについて解説します。そもそも受け入れる必要があるのか? ということのほかにも、いろいろ設定が必要です - OSに付属するシェルスクリプトを読んで技術を盗む (2012/1/27)
シェルスクリプトマスターに近づくには、他人から技術を盗まなければならない。OS付属のスクリプトから技術を盗もう
|
|
キャリアアップ
スポンサーからのお知らせ
- - PR -
イベントカレンダー
- - PR -

