ローカルPCのApache + PHP の環境で、Visual Studio Code を使用してデバッグを行う方法を備忘録として書きます。
XDebugとVisual Studio Code のプラグインであるPHP Debugを使用します。
ブレークポイントでプログラムを停止するところまでをやっていきます。
- Windows10 Home 64bit
- Apache2.4.55
- PHP8.0.27
- Visual Studio Code 1.76.2
XDebug のインストール
phpinfoの表示
インストールするためには、phpinfoの情報が必要となります。ローカルPCからブラウザでphpinfoを表示させます。表示させる方法については↓の記事を参考にしてください。
data:image/s3,"s3://crabby-images/61a6f/61a6f682bf1e6cad4cc23a8fe718baa27543996c" alt=""
data:image/s3,"s3://crabby-images/ff1f2/ff1f23a26a8d1c137230f4f83f2b34926cd76f17" alt=""
phpinfoの内容は、後から必要になります。
XDebugのインストール方法
ブラウザでこちらのURLにアクセスします。
↓の黄色枠に、phpinfoの表示内容をコピペします。
data:image/s3,"s3://crabby-images/bcc0b/bcc0b1d8f32b332cd7ac95f39062d6a3f7bfcc2e" alt=""
data:image/s3,"s3://crabby-images/25738/257386503326e49dc69fe3ddf920b8a2c8066bcc" alt=""
phpinfoの内容を貼り付けた後に、Analyse my phpinfo() output を押します。
data:image/s3,"s3://crabby-images/5daa7/5daa74b762e4e45fecc44c41a26523c98fa01be0" alt=""
↓の内容が表示されました。この内容を参考に、インストールを行います。
data:image/s3,"s3://crabby-images/bec14/bec14a4d488b04df1f7ac60f5fc2861ac53d2c95" alt=""
php_xdebugのインストール
Instructions に表示されている通り、以下を行います。
- php_xdebug-3.2.1-8.0-vs16-x86_64.dllをダウンロードします。
- ダウンロードしたファイルを、(phpのインストールフォルダ)\extに移動します。
- php_xdebug.dll に名前を変えます。
php.ini に以下の内容を追記します。Instructions と違う内容となってます。
[XDebug 3.X.X]
xdebug.mode=debug
xdebug.start_with_request=yes
zend_extension = "(php_xdebug.dllのパス)"
Apacheを再起動して、インストール完了です。
PHP Debug プラグインのインストール
Visual Studio Code を起動し、拡張機能を選択します。
data:image/s3,"s3://crabby-images/d1253/d1253b97472baf26cc83a06ac6524d6a5bdede5a" alt=""
phpdebug と入力し、PHPDebugを選択します。
data:image/s3,"s3://crabby-images/3bb14/3bb14e9efe843fa33a938e2a894f391b9ce2ac88" alt=""
しばらく待つとインストールが完了します。
PHP のデバッグ
先ほど表示したphpinfo のコードでブレークポイントを設定し、デバッグしてみます。
Visual Sdudio Codeを起動し、apacheのデータフォルダを開きます。
データフォルダは、apache フォルダのhtdocsフォルダとなります。
data:image/s3,"s3://crabby-images/f4298/f4298448509919c7486599816eb7857f58388df7" alt=""
phpinfo.php を開き、2行目にブレークポイントを設定します。
data:image/s3,"s3://crabby-images/2ec54/2ec541d263a76df286bd1dd3a9ae26c14a457c8e" alt=""
右上のデバッグのマークをクリックします。
data:image/s3,"s3://crabby-images/c4dc5/c4dc5e6eb2e0aed3775b5da311eaf6942ce32a08" alt=""
画面の左下にデバッグマークがでてくるのでクリックします。そのあと、構成の追加を押します。
data:image/s3,"s3://crabby-images/aa580/aa580bc885e98e9fc4b3ee8fcf8588fe2f0909e3" alt=""
launch.jsonが開かれます。Xdebug の設定が開かれます。追加設定することはないので、そのまま閉じます。
data:image/s3,"s3://crabby-images/a665a/a665ad88ce5ed35c8091568c5fe92675993782d1" alt=""
- 右下のListen for Xdebug(htdocs) を押します。
- 中央上のListen for Xdebugを選択します。
data:image/s3,"s3://crabby-images/6b8bd/6b8bd8db97b0abd3cf9b25c6b241a0a2e970d9b4" alt=""
左側の実行ボタンを押します。デバッグモードが開始します。
data:image/s3,"s3://crabby-images/26104/26104cbc820d2465bf53c31a2ef75dd783f11b3f" alt=""
ブラウザから、http;//localhost/phpinfo.php にアクセスします。アクセスすると↓の画面のように、phpinfo()でプログラムを停止することができました。
ウォッチ式で変数を見たり、コーススタックも見たりできそうです。
data:image/s3,"s3://crabby-images/d1a49/d1a491940661736fe3a4a56370eea0e2fcc43231" alt=""
コメント