In the previous tutorial, we have discussed debugging a PHP program using Eclipse for PHP on Windows. In this tutorial, we will go further and remote debug the PHP applications deployed on a web server. It assumes that Java, PHP, and Apache Web Server are already installed on the system. You might have already installed PHP and Apache Web Server while installing WAMP or XAMPP.
This tutorial also assumes that you have already gone through How To Debug PHP In Eclipse On Windows to get the basic concepts of debugging.
Notes: You may follow How To Install PHP 7 On Windows or How To Install PHP 8 On Windows to install the most recent version of PHP 7 or PHP 8. The other relevant tutorials include How To Install Java 11 On Windows, How To Install Java 15 On Windows, How To Install OpenJDK 15 On Windows, How To Install WampServer on Windows, How To Install XAMPP On Windows 10, How To Install XAMPP With PHP 8 On Windows 10, and How To Install Eclipse for PHP on Windows.
Also, this tutorial provides all the steps required to debug PHP using Xdebug 3.
You can also follow NetBeans tutorials at How To Debug PHP In NetBeans On Windows, How To Remote Debug PHP Web Apps In NetBeans On Windows, and How To Debug PHP Web Apps In NetBeans On Windows.
Install PHP
You can install PHP by following How To Install PHP 7 On Windows, How To Install PHP 8 On Windows, How To Install WampServer on Windows, How To Install XAMPP On Windows 10, or How To Install XAMPP With PHP 8 On Windows 10.
Install Java
You can install Java by following How To Install Java 11 On Windows, How To Install Java 15 On Windows, or How To Install OpenJDK 15 On Windows.
Install Eclipse for PHP
You can install Eclipse for PHP by following How To Install Eclipse for PHP on Windows.
Debugging Concepts
You can learn the debugging concepts by following How To Debug PHP In Eclipse On Windows. Also, make sure that you have configured the PHP used by your web server. This tutorial also assumes that you have properly configured Xdebug and tested it using the basic program as discussed in How To Debug PHP In Eclipse On Windows.
Create Project
In this step, we will create the project to remotely debug the PHP script. Create the HelloWorld project by clicking the New -> Project as shown in Fig 1.
data:image/s3,"s3://crabby-images/ac394/ac3948cfd1e0be5b665d41c8dacf8016c7b74768" alt="Remote Debug PHP on Windows using Eclipse - Create Project Remote Debug PHP on Windows using Eclipse - Create Project"
Fig 1
Choose the option PHP Project as shown in Fig 2.
data:image/s3,"s3://crabby-images/c3883/c388320a49ef40911652e2c7873e03d2927798b4" alt="Remote Debug PHP on Windows using Eclipse - Create Project Remote Debug PHP on Windows using Eclipse - Create Project"
Fig 2
Now click the Next Button. The next wizard provides options to configure the project name, location, and also provides options to specify the PHP version as shown in Fig 3.
data:image/s3,"s3://crabby-images/9d144/9d144d32acb44d8b6e54913d259263824d583f0e" alt="Remote Debug PHP on Windows using Eclipse - Configure Project Remote Debug PHP on Windows using Eclipse - Configure Project"
Fig 3
Now, click the Finish Button to create the project. It creates the HelloWorld project as shown in Fig 4.
data:image/s3,"s3://crabby-images/d1ff9/d1ff90eaceb49cbfedcde951acbafdd3b1ac62b0" alt="Remote Debug PHP on Windows using Eclipse - Project Remote Debug PHP on Windows using Eclipse - Project"
Fig 4
Now create the PHP script i.e. index.php by right-clicking on Project -> New -> PHP File as shown in Fig 5.
data:image/s3,"s3://crabby-images/3d6d1/3d6d161845cfc41cd540795cd599306cc0a04611" alt="Remote Debug PHP on Windows using Eclipse - Create PHP File Remote Debug PHP on Windows using Eclipse - Create PHP File"
Fig 5
Now, configure the PHP file as shown in Fig 6.
data:image/s3,"s3://crabby-images/3d998/3d99848fd5332de80434c9b0c715843a8e176ce6" alt="Remote Debug PHP on Windows using Eclipse - Configure PHP File Remote Debug PHP on Windows using Eclipse - Configure PHP File"
Fig 6
Click the Finish Button to create index.php. Also, update the file as shown in Fig 7.
data:image/s3,"s3://crabby-images/336a8/336a8a0ccc183d8e667dbcdaa1485b2f7336e87c" alt="Remote Debug PHP on Windows using Eclipse - Update PHP File Remote Debug PHP on Windows using Eclipse - Update PHP File"
Fig 7
This is all about creating the PHP project and writing the first program to learn the debugging concepts. Now, create the appropriate alias for the web server so that we can access the project via browser as shown in Fig 8.
data:image/s3,"s3://crabby-images/73892/73892231d5dbeeed45e02f8dde76c94def9441c1" alt="Remote Debug PHP on Windows using Eclipse - PHP Output Remote Debug PHP on Windows using Eclipse - PHP Output"
Fig 8
Execute Project
In this step, we will execute the project from Eclipse. Now, right-click the Project -> Run As -> PHP Web Application as shown in Fig 9.
data:image/s3,"s3://crabby-images/8f8e5/8f8e5eeda7b38f1487cd89b9159979ff97c95e23" alt="Remote Debug PHP on Windows using Eclipse - Launch Project Remote Debug PHP on Windows using Eclipse - Launch Project"
Fig 9
In the absence of PHP server configuration, it might show the error - Failed to launch on PHP server, Reason: Launch target not found as shown in Fig 10.
data:image/s3,"s3://crabby-images/a9839/a9839c562f6c0397ff6c40aca67035e1cb2576c8" alt="Debug PHP on Windows using Eclipse - Failed to launch on PHP server - Launch target not found Debug PHP on Windows using Eclipse - Failed to launch on PHP server - Launch target not found"
Fig 10
We must create the Run Configuration to execute the project as a Web Application. It can be done as shown in Fig 11.
data:image/s3,"s3://crabby-images/699e3/699e3aace3bfa74f4bfc3539163466d3a57cbcc6" alt="Remote Debug PHP on Windows using Eclipse - Run Configuration Remote Debug PHP on Windows using Eclipse - Run Configuration"
Fig 11
Now, click the Run Configurations as shown in Fig 11 and click the New Launch Configuration as shown in Fig 12.
data:image/s3,"s3://crabby-images/e0781/e07817a8aaea518399f12045e3a615d53c78670e" alt="Remote Debug PHP on Windows using Eclipse - Run Configuration Remote Debug PHP on Windows using Eclipse - Run Configuration"
Fig 12
Configure the Run Configuration as shown in Fig 13.
data:image/s3,"s3://crabby-images/5bc6e/5bc6ee598a4043254fdba827d3c8ab3554e06dfb" alt="Remote Debug PHP on Windows using Eclipse - Configure Run Configuration Remote Debug PHP on Windows using Eclipse - Configure Run Configuration"
Fig 13
Now click the Apply Button to save the Run Configuration and click the Run Button to launch the project on the Web Browser. It will execute the project and shows the output within the in-built browser as shown in Fig 14.
data:image/s3,"s3://crabby-images/708bb/708bb31a8522ba4a94e7d16db86ca91552bf183f" alt="Remote Debug PHP on Windows using Eclipse - Project Output Remote Debug PHP on Windows using Eclipse - Project Output"
Fig 14
Remote Debug
In the previous steps, we have created the HelloWorld PHP project in eclipse and executed it by creating the Run Configuration. In this step, we will debug the same project using the same Run Configuration. Now add a breakpoint at line number 6 as we did in How To Debug PHP In Eclipse On Windows. It should show the breakpoint as shown in Fig 15.
data:image/s3,"s3://crabby-images/21732/21732640cd03a0f4881989f144528d6ab1fe78c3" alt="Remote Debug PHP on Windows using Eclipse - Add Breakpoint Remote Debug PHP on Windows using Eclipse - Add Breakpoint"
Fig 15
Now, click the Debug and choose HelloWorld Run Configuration as shown in Fig 16.
data:image/s3,"s3://crabby-images/5a79e/5a79e7f37b7df903678151133fd76486c9053749" alt="Remote Debug PHP on Windows using Eclipse - Start Debugger Remote Debug PHP on Windows using Eclipse - Start Debugger"
Fig 16
It will show the Launch Error as shown in Fig 17. The error states - Launch Configuration 'HelloWorld' could not be started in debug mode. There is no debugger specified in corresponding 'Default PHP Web Server' server configuration.
data:image/s3,"s3://crabby-images/164d3/164d3ea63e58315662e847373bff06ba9585bbba" alt="Debug PHP on Windows using Eclipse - Launch Error - Launch Configuration 'HelloWorld' could not be started in debug mode. Debug PHP on Windows using Eclipse - Launch Error - Launch Configuration 'HelloWorld' could not be started in debug mode."
Fig 17
Now open the Debug Configurations Wizard as shown in Fig 18.
data:image/s3,"s3://crabby-images/2f631/2f63152e88a33579b47d4d1c2371b17116763460" alt="Remote Debug PHP on Windows using Eclipse - Debug Configuration Remote Debug PHP on Windows using Eclipse - Debug Configuration"
Fig 18
It will show the Debug Configuration for the HelloWorld Run Configuration with the Debug Tab as shown in Fig 19.
data:image/s3,"s3://crabby-images/25ecf/25ecf9e5cbcbc0886a2f009da14979ecf9a15c3c" alt="Remote Debug PHP on Windows using Eclipse - Debug Configuration Remote Debug PHP on Windows using Eclipse - Debug Configuration"
Fig 19
Now click the Debug Tab to view the debugger configuration as shown in Fig 20.
data:image/s3,"s3://crabby-images/e8918/e8918461e2d57da1a475e17d0594feedec536806" alt="Remote Debug PHP on Windows using Eclipse - Debug Configuration Remote Debug PHP on Windows using Eclipse - Debug Configuration"
Fig 20
It shows that there is no debugger configured for the Default PHP Web Server. Now, click the Configure Button to configure the debugger. It shows the options to configure the debugger as shown in Fig 21.
data:image/s3,"s3://crabby-images/e90a3/e90a36ae54ed164b357185f223f318b1dff6252e" alt="Remote Debug PHP on Windows using Eclipse - Configure Debug Configuration Remote Debug PHP on Windows using Eclipse - Configure Debug Configuration"
Fig 21
Choose Xdebug as the debugger and specify the port as 9003 to debug with Xdebug 3. Also, click the Finish Button to close the wizard. It will show the debugger configured by us as shown in Fig 22.
data:image/s3,"s3://crabby-images/e1ff1/e1ff1928875a02b09059ff8f528f66aa2faa8ccf" alt="Remote Debug PHP on Windows using Eclipse - Debug Configuration Remote Debug PHP on Windows using Eclipse - Debug Configuration"
Fig 22
Now, click the Apply Button and click Debug to start debugging the PHP script. It will stop the pointer at line number 1 and ask to switch to Debug Perspective as shown in Fig 23.
data:image/s3,"s3://crabby-images/e9b20/e9b20dda126ac55c2f4dffc9c500f32e3597b69f" alt="Remote Debug PHP on Windows using Eclipse - Switch Perspective Remote Debug PHP on Windows using Eclipse - Switch Perspective"
Fig 23
Now, click the Switch Button to switch to Debug Perspective. The Debug Perspective should be similar to Fig 24.
data:image/s3,"s3://crabby-images/93ef8/93ef8176c91969c4921bf0e94ec7aef5a84bf884" alt="Remote Debug PHP on Windows using Eclipse - Debug Perspective Remote Debug PHP on Windows using Eclipse - Debug Perspective"
Fig 24
Now click the Resume Button to move the debugger pointer as shown in Fig 25.
data:image/s3,"s3://crabby-images/5338d/5338d6c6bdf6eb2453fe85ea58d276228c20578a" alt="Remote Debug PHP on Windows using Eclipse - Resume Debugger Remote Debug PHP on Windows using Eclipse - Resume Debugger"
Fig 25
Fig 25 shows that the debug pointer is moved to line number 6 after clicking the Resume Button. Now again click the Resume Button to move to the next breakpoint as shown in Fig 26.
data:image/s3,"s3://crabby-images/2debf/2debf621ee34b07e6ef192887ba910e4c2ea19b3" alt="Remote Debug PHP on Windows using Eclipse - Resume Debugger Remote Debug PHP on Windows using Eclipse - Resume Debugger"
Fig 26
Also, check the variables stack. The variable $i is set to 1 and the variable $number is set to Zero after the first iteration of the for loop.
This is how we can debug the PHP Web Applications in Eclipse using the Xdebug. Now, double-click the breakpoint to remove it and again click the Resume Button to execute the script. It should show the output in the in-built browser as shown in Fig 27.
data:image/s3,"s3://crabby-images/9060d/9060d44af4ab87dd5c3338069fce4d89106176a0" alt="Remote Debug PHP on Windows using Eclipse - Project Output Remote Debug PHP on Windows using Eclipse - Project Output"
Fig 27
Note that the debug session parameter is configured while debugging the project which is missing in case we run the project using the Run Configuration as shown in Fig 14.
Summary
This tutorial provided the reference links to install PHP 7, PHP 8, Java 11, Java 15, WampServer, XAMPP, and Eclipse for PHP. It also provided the steps to create the HelloWorld project and execute the PHP script as a Web Application. The last section of the tutorial provided the steps to debug the same PHP script by configuring the Debugger.