Windows7でPHP5のIntl拡張を有効にする方法


概要

PHPでUnicode正規化などを行うには、国際化用拡張モジュール(Intl)が必要です。
このモジュールを有効にするには、ICUライブラリをインストールしなくてはなりません。

しかし、Windowsでこれをインストールし、且つ、PHPで使えるよう有効化するのに一手間かかりました。
調べても調べても、出てくるのはLinuxやMacやXAMPPでの方法ばかり。
yumだのbrewだのphp-configだの… Windows版Apache & PHP使いの私にどうしろというのだ‼‼

日本語記事が見つからず、この方法にたどり着くまで一手間かかったため、
備忘録も兼ねて、WindowsでIntlを有効化する方法について投稿することにします。

注意

  • 「ディレクトリ」を「フォルダ」と表記していますが、仕様です
  • 無駄に画像が多いです
  • 初心者向けのと見せかけて、実はそうじゃなかったりするかも
  • ここに書かれている内容は2016年7月20日時点のものです。情報が古くなり、参考にならなくなるかもしれません。その場合、コメントでお知らせください。生きていたら、そして気が向いたら修正します。
  • この手順に従った結果、環境が壊れたりしても責任は取れません。参考にする場合は自己責任でお願いします。

私の環境

OS

Windows 7 Home Premium SP1 64bit

ノートPCのOSまんまです。仮想環境なんて使っていません。
おかげで、ググッてヒットするLinuxやMacでの方法がまるで参考になりませんでした。同じ思いをしている方の助けになると良いな…

Webサーバ

Apache 2.4.16 VC11 Win64

Apache Loungeからzip形式でダウンロードし、インストールしたものです。OSが64bitなので、Win64を選択しています。
ダウンロードしたファイル名は「httpd-2.4.16-win64-VC11.zip」でした。

私は独習PHP 第2版でPHPを学んでいたため、XAMPPなんてものは使っていません。ApacheやPHPも、直接ダウンロード&インストールしていました。
おかげで、ググッてヒットするXAMPPでの方法がまるで参考に(ry

PHP

PHP 5.6.22 VC11 x64 Thread Safe

PHP For Windowsからzip形式でダウンロードし、インストールしたものです。OSが64bitなので、x64を選択しています。また、Thread Safe版を選択しました。
ダウンロードしたファイル名は「php-5.6.22-Win32-VC11-x64.zip」でした。
Apacheでは、モジュール版として動作させています。

上述の通り、XAMPPなんてイカしたものは使っていなかったため、直接ダウンロードし、Cドライブ直下で展開しました。
おかげで(ry

手順

WindowsでWebサーバやPHPを直接インストールしている、崇められてしまうような私の環境。
そんな私の環境に合う方法は以下のやり方でした。順に説明していきます。

事前準備

この投稿で解説している方法を試すなら、その前に、以下の準備が整っているか確認してください。

  • 「メモ帳」以外のテキストエディタをインストール済みで、使用できる

    そもそもPHPを始める段階でインストール済みだと思いますが一応のため。
    Windows標準の「メモ帳」を使うつもりなら、絶対に止めてください。
    代わりに、AtomとかNotepad++とかを使いましょう。

  • Windows版のApache、及び、モジュール版PHPを導入済み。

    つまり、PHPが使える。
    PHPも使えないような環境は流石に想定できませんし、面倒見きれません。
    最低限、Hello Worldが実行される状態を整えてください。

    また、私の環境がモジュール版PHPのため、CGI版PHPは対象外です。

  • zipファイルを展開(解凍)できる。

    エクスプローラーの機能とかでzipファイルを展開できるか確認してください。
    できない、あるいは分からない場合、zipファイルを展開(解凍)するソフト1をインストールしてください。

  • Apacheのインストールディレクトリ(フォルダ)の場所(パス)を把握できている。

    私の場合は、「C:\Apache24」がインストールディレクトリになります。
    httpd.conf」ファイルの場所で例示するなら、「C:\Apache24\conf\httpd.conf」となります。

    どうしても分からない場合、もしかしたら「phpinfo.php」ファイルの「Server Root」という箇所に表示されているかもしれないので、確認してみてください。

    「そんなファイルなんて知らない」という場合は、「phpinfo.phpファイルを作っておく」を参考に作ってみてください。

なお、XAMPPとかでPHPを導入している場合は、この方法のせいでかえって壊れるかもしれません。
私はこれで成功しましたが、自分の環境で試す場合は自己責任でお願いします。

phpinfo.phpファイルを作っておく

Intlが有効化したかどうか確かめる場合や、「php.ini」ファイルの場所が分からない場合などに備えて、phpinfo()関数を実行するだけのファイルを作っておきましょう。
既にあるなら、作らなくても大丈夫です。

以下のPHPファイルを書いてください。ここではファイル名を「phpinfo.php」としていますが、別に他のファイル名でも構いません。

phpinfo.php
<?php
phpinfo();

そしてこのファイルを、PHPが実行されるフォルダに保存してください。
保存したら、このファイルをWebブラウザで開いてみましょう。

こんな感じのページが表示されればOKです。

この中に、「intl」と書かれた項目が無いことを確認してください。
この項目がある場合、Intlは既に導入済みです。つまり、この投稿に書かれている事を真似る必要はありません。

この項目があるにも関わらず、Intlが使えない場合は…
すみませんが、この投稿、及び、私の知識では対処できそうにありません。

スタック・オーバーフローテラテイルYahoo!知恵袋なんかで質問すれば、解決するかもしれません。

ICUライブラリをダウンロードする

この手順は省略できるかもしれません。詳細はコメントを参照してください

まずは、ICUライブラリをダウンロードします。公式サイトに行き、「Navigation」という部分の中にある「Download ICU」というリンクを開きます。

公式サイト:http://site.icu-project.org/

その中に、ダウンロードページヘのリンクがずらりと並んでいます。その中で、「ICU4C」という列の一番上に書かれてるバージョン(最新版)のリンクを開きます。
これを書いている時点のダウンロードページではICU 57が最新版なので、「57.1」と書かれているリンクがこれにあたります。

※将来的にこの「ICU4C」という名前が「ICU5C」とか「ICU6C」に変わるかもしれません。その場合は、以降の説明をうまい具合に読み替えてください。

上手く移動すると、「ICU4C Download」という見出しに移動しているはずです。
この中の「ICU4C Binary Download」から、
「Windows (x86 32-bit) Visual Studio 10」とか「Windows (x86 64-bit) Visual Studio 10」とかって
書いてある部分の左隣にあるzipファイルのリンクを開いてダウンロードしましょう。

私のOSは64bitなので、「Windows (x86 64-bit) Visual Studio 10」の部分にある「icu4c-57_1-Win64-msvc10.zip」をダウンロードしました。
32bitの場合は、「Windows (x86 32-bit) Visual Studio 10」の項目にあるzipファイルをダウンロードしてください。

ダウンロードしたzipファイルの保存場所はどこでも良いです。例えばデスクトップとか、「ダウンロード」フォルダの中とかでも構いません。
ただし、後述の問題があるため、保存する場所に「icu」というフォルダが無いことを確認しましょう。
Windowsは大文字小文字を区別しないため、「ICU」や「Icu」、「iCU」、「IcU」などのフォルダでも駄目です。

不安な場合は、新しくフォルダを作り、その中にzipファイルをダウンロードしてしまいましょう。
ちなみに私は、「ダウンロード」フォルダの中に「ICU」フォルダを作り、その中にzipファイルをダウンロードしました2

ICUライブラリをインストールする

zipファイルを展開する

この手順は省略できるかもしれません。詳細はコメントを参照してください

ダウンロードしたICUライブラリのzipファイルを展開します。展開方法は展開ソフトによるので、ここでは割愛します。

展開するとき、「icu」というフォルダが作られ、その中にファイルが展開されてしまう事があります。また、既に「icu」フォルダがある場合は、その中に展開されたファイルが追加されてしまいます。
このため、zipファイルを展開する前に、zipファイルのあるフォルダに「icu」フォルダが無いか確認してください。上述したとおり、Windowsは大文字小文字を区別しないため、「ICU」や「Icu」、「iCU」、「IcU」などのフォルダでも駄目です。
ダウンロードするときに確認済みなら問題ありません。

展開すると、「icu」というフォルダが作られると思います。そのフォルダを開きましょう3
icu」フォルダの中には、32bit版のzipなら「bin」、64bit版のzipなら「bin64」というフォルダがあるはずです。
私の場合は64bit版をダウンロードしたので、「bin64」になります。

以降は、このフォルダ名「bin64」で説明を続けることにします。

icu*.dll」を「bin」フォルダにコピーする

この「bin64」フォルダを開きます。
するとズラッとファイルが並んでいるハズ。

この中のうち、「icu*.dll」というファイルを探します4
私の場合、以下のファイルがこれに該当していました。

  • icudt57.dll
  • icuin57.dll
  • icuio57.dll
  • icule57.dll
  • iculx57.dll
  • icutu57.dll
  • icuuc57.dll

これらのファイルを、全て、Apacheのインストールディレクトリにある「bin」フォルダの中にコピーします5
私の場合、「C:\Apache24」がApacheのインストールディレクトリになります。なので、「C:\Apache24\bin」フォルダの中にコピーします。

以上でインストールは終了です。

php.iniを編集する

ここまでくれば、Intlの有効化まであと少しです。
まずは、「php.ini」ファイルをテキストエディタで開きます。

php.ini」ファイルの場所が分からない場合は、「phpinfo.phpファイルを作っておく」で作った(もしくは、既に作成済みの)「phpinfo.php」ファイルをWebブラウザで開き、「Loaded Configuration File」という項目を確認してみましょう。

私の場合、「C:\php-5.6.22-Win32-VC11-x64\php.ini」が「php.ini」ファイルの場所になります。

このファイルをテキストエディタで開き、以下の行を探してください。
(もしあれば、)テキストエディタの検索機能で「extension」とか「intl」とか検索してみると簡単に見つかるかもしれません。

php.ini
;extension=php_intl.dll

この行の先頭にあるセミコロン(;)を取り、以下のように修正します。

php.ini
extension=php_intl.dll

修正したら、「php.ini」ファイルを上書き保存しましょう。

Apacheを再起動し、Intlが有効化したか確認する

php.ini」ファイルを保存したら、Apacheを再起動してください。
再起動後、「phpinfo.php」をWebブラウザで開き、「intl」と書かれた項目がある事を確認してください。

もしあれば、導入成功です。お疲れ様でした!

参考

あとがき

この方法を見つけるまで、私は徹夜して調べました。
次の日は学校だったのですが、徹夜による眠気に耐え切れず、講義中に寝てしまうという失態を犯してしまいました。

私と同じ轍を踏む犠牲者が現れないことを切に願います。
どうかこれを参考に、WindowsでのIntl導入を楽に成功させられますように…


  1. 7-ZipLhaplusなど。なお、私はLhaplusを使っています。 

  2. 新しいフォルダの「中」には何も無いため、『保存する場所に「icu」というフォルダは無い』状態にできます。『「ダウンロード」フォルダの中に作った「ICU」フォルダの中』も同じです。 

  3. zipの展開ソフトによっては、「icu」フォルダを新しいウィンドウで勝手に開くものもあります。その場合は、わざわざ開かなくても大丈夫です。 

  4. 探すときは、エクスプローラーの検索窓(右上の「bin64の検索」と書いてある入力欄)に「icu*.dll」と入力すると、30秒くらい待たされてから(場合によっては数秒で)該当するファイルだけが表示されます。これで探すと楽です。 

  5. 複数のファイルをコピーする時は、Ctrlキーを押下しながらファイルをクリックすると、複数選択できます。またShiftキーで範囲内の一括選択ができますし、何も無い部分からマウスでドラッグして四角形を描くことでも選択できます。複数選択してからコピーすると移動が楽です。