The debug (debugging) methods in PHP are: 1. Add echo, var_dump, print_r and exit statements in the PHP code, and print information through the browser for debugging; 2. Use Xdebug for debugging; 3. Through Console terminal for debugging.
The operating environment of this tutorial: Windows 7 system, PHP version 7.1, DELL G3 computer
Debug by printing information from the browser
Method
Add echo, var_dump, print_r and exit, view the output in the browser.
Advantages and Disadvantages
Advantages:
Disadvantages:
Tips
When debugging, In order to format output variables, you often need to implement your own dump()
function in the project. Using Composer, the dump()
function in the symfony/var-dumper
package can be installed globally, making it available to all projects without modifying the project.
symfony/var-dumper
Package: ${HOME}/.config/composer
directorycomposer global require symfony/var-dumper
php.ini
file and include the specified file before executing the PHP codeauto_prepend_file = ${HOME}/.config/composer/vendor/autoload.php
Use Xdebug Debugging
XDebug is a C/S structure, where Client is Xdebug installed in PHP, Server is the plug-in installed in IDE, and uses DBGP protocol to communicate. When PHP runs a script, it sends debugging information to the IDE through the Xdebug plug-in and receives control signals from the IDE.
You need to install and enable Xdebug for PHP, and then set up the IDE's Xdebug plug-in so that the two can communicate.
Advantages and Disadvantages
XDEBUG_SESSION_START
ParametersWeb App debugging
For web applications, To enable Xdebug debugging mode, additional flags must be added to the request sent by the browser. You can add XDEBUG_SESSION_START=session_name
in the GET/POST/Cookie parameters, so that Xdebug will understand that this request needs to be debugged and connect to the IDE.
But it is troublesome to set it manually every time. There are two ways to simplify the operation:
XDEBUG_SESSION_START=session_name
. Debug through the console terminal (CLI mode)
For non-web applications, such as scheduled tasks or unit tests, you can directly Debugging in the console.
In PhpStorm, use the Alt F12
shortcut key to open the command line terminal. However, because only one terminal can be displayed in the IDE, the debugging terminal after debugging is turned on will cover the command line terminal, so it is better to open a separate command line terminal (you can use a DOS window or PowerShell under Windows).
Method and principle
Web applications debug requests through GET/POST/Cookie parameter flags, while non-web applications enable debugging by setting environment variables in the command line terminal. .
Two steps:
XDEBUG_CONFIG="idekey=session_name"
, this idekey needs to be matched with php.ini
Some of the idekey settings are the same. IDE usually provides shortcut operations. For PHPStorm, you can refer to Debugging PHP CLI scripts with PhpStorm.
After starting debugging through the IDE, the IDE will start the Xdebug plug-in to listen to a certain port (PhpStorm defaults to 9000, but this conflicts with PHP-FPM and can be changed to 9001) to obtain the debugging information returned by the PHP server.
D:\lnmp\php72\php.exe -dxdebug.remote_enable=1 -dxdebug.remote_mode=req -dxdebug.remote_port=9001 -dxdebug.remote_host=127.0.0.1 D:\lihongfeng\workspace\untitled\index.php
export XDEBUG_CONFIG="idekey=session_name" // 设置环境变量 echo $XDEBUG_CONFIG // 查看环境变量 unset XDEBUG_CONFIG // 删除环境变量
set XDEBUG_CONFIG="idekey=session_name" // 设置环境变量 echo %XDEBUG_CONFIG% // 查看环境变量 set XDEBUG_CONFIG // 查看环境变量 set XDEBUG_CONFIG= // 删除环境变量
推荐学习:《PHP视频教程》
The above is the detailed content of What are the debugging methods in PHP?. For more information, please follow other related articles on the PHP Chinese website!