最近Visual Studio Code(以下VSCodeといいます)を使ってPHPの勉強をしています。
VSCode上でデバッグができるようにした際,ネットであれこれ調べたのですが書いてあることがかなりまちまちで意外と手こずってしまいました。
結論としては諸々の記事よりも手順は簡略化できそうなので,それらをまとめたものを紹介します。
環境
- Windows10
- VSCodeのバージョン:1.45.1
- xampp(Cドライブ直下にインストール)のバージョン:3.2.4
- 作業ドライブ:Z:\Dropbox\htdocs\
「XDebug」の設定
XDebugがあるかどうかの確認(なければインストール)
多くのサイトではXDebugをインストールしなければならないと書いてあるのですが,下記サイトによると最近のxamppにはデフォルトで用意されていると書いてあります。
![](https://helog.jp/img/og.png)
確かに私のxamppにも入っていました。
C:\xampp\php\ext\ に php_xdebug.dll というファイルがあればOKです。
なければ下記サイトからインストールしましょう。
php.iniの設定
C:\xampp\php\ にある php.iniを編集します。
一番下に次の内容を追加します。
[XDebug]
zend_extension = "C:\xampp\php\ext\php_xdebug.dll"
xdebug.remote_enable = 1
xdebug.remote_autostart = 1
この設定が人によって一番まちまちなところです。
が,最低限動かすのであればとりあえずこれだけでよいのではないかと思います。
設定内容については本家サイトのほか,下記サイトがわかりやすかったです。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-412672c5f0600ab9a64263b751f1bc81.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9JTVCUEhQJTVEJTIwWGRlYnVnJTIwJUUzJTgxJUFFJUUzJTgzJUFBJUUzJTgzJUEyJUUzJTgzJUJDJUUzJTgzJTg4JUUzJTgzJTg3JUUzJTgzJTkwJUUzJTgzJTgzJUUzJTgyJUIwJUUzJTgwJTgxJUU3JTkwJTg2JUU4JUE3JUEzJUUzJTgxJTk3JUUzJTgxJUE2JUUzJTgxJTg0JUUzJTgxJUJFJUUzJTgxJTk5JUUzJTgxJThCJUVGJUJDJTlGJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmcz1kZGU1M2Y0MTkwY2U0NzI2ZjU3ODg4MTU1ZGUyMDgyMA&mark-x=142&mark-y=57&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9NzcwJnR4dD0lNDBjYXN0YW5lYWkmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTBiMmRjNjcxMzFiZWRiODA1ZjY0YzU5MWFhODMyOWM5&blend-x=142&blend-y=486&blend-mode=normal&s=87ddae7c3da6a54c6ef11ffcab766b28)
また,XDebugをインストールした場合はファイル名が違っているかもしれないので,そうした場合は適宜訂正してください。
「PHP Debug」の設定
「PHP Debug」のインストール
VSCodeの拡張機能である「PHP Debug」をインストールします。
![PHP Debugのインストール手順](https://yamanekosuke.com/wp-content/uploads/2020/06/phpDebugInstall01-800x422.jpg)
- 拡張機能タブを押す
- 「php debug」を検索
- インストールボタンを押してインストール
launch.jsonファイルの編集
launch.jsonファイルを編集しないとうまく動作しないことが多いようです。私もそうでした。
編集の手順は次のとおりです。
![](https://yamanekosuke.com/wp-content/uploads/2020/06/phpDebugInstall02-800x335.jpg)
- デバッグタブを開く
- 「launch.jsonファイルを作成します」をクリック
- 「PHP」を選択
そうすると下記のようなファイルが開かれるはずです。
{
// IntelliSense を使用して利用可能な属性を学べます。
// 既存の属性の説明をホバーして表示します。
// 詳細情報は次を確認してください: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "Listen for XDebug",
"type": "php",
"request": "launch",
"port": 9000
},
{
"name": "Launch currently open script",
"type": "php",
"request": "launch",
"program": "${file}",
"cwd": "${fileDirname}",
"port": 9000,
},
]
}
これに
“runtimeExecutable”: “C:\xampp\php\php.exe”
を追加します。
{
// IntelliSense を使用して利用可能な属性を学べます。
// 既存の属性の説明をホバーして表示します。
// 詳細情報は次を確認してください: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "Listen for XDebug",
"type": "php",
"request": "launch",
"port": 9000
},
{
"name": "Launch currently open script",
"type": "php",
"request": "launch",
"program": "${file}",
"cwd": "${fileDirname}",
"port": 9000,
"runtimeExecutable": "C:\\xampp\\php\\php.exe"
},
]
}
保存して閉じます。設定は以上です。
動作確認
なんでもいいのでphpのファイルを開きます。
![PHP Debug動作確認1](https://yamanekosuke.com/wp-content/uploads/2020/06/phpDebugTest01-800x465.jpg)
- 上画像矢印のように行数字の左横をクリックして適当にブレークポイントを作っておきます。
- デバッグタブを開きます。
- 実行ボタンを押します。その際に横のプルダウンメニューは「Listen currently open script」にしておきます。
![PHP Debug動作確認2](https://yamanekosuke.com/wp-content/uploads/2020/06/phpDebugTest02-800x465.jpg)
こんな感じで先ほど設定したブレークポイントで止まり,デバッグタブの変数が表示されていればOKです。
その他参考にしたサイト
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-412672c5f0600ab9a64263b751f1bc81.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9VmlzdWFsJTIwU3R1ZGlvJTIwQ29kZSVFMyU4MSVBN1BIUCVFMyU4MiU5MiVFMyU4MyU4NyVFMyU4MyU5MCVFMyU4MyU4MyVFMyU4MiVCMCVFMyU4MSU5OSVFMyU4MiU4QiVFNiU5NiVCOSVFNiVCMyU5NSZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnM9MDIyOTI2ZjBhZjRhNzg5MTIxZWM1YjgwZGVmYzU0ZWQ&mark-x=142&mark-y=57&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9NzcwJnR4dD0lNDBheWs1MjMmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTBjMzI1YmQwYTMxMWUzNmNmZDVhNTg0YmQ3MzcyMWRm&blend-x=142&blend-y=486&blend-mode=normal&s=e3cff6c9056152a9a4585209800ff6f2)
コメント