Xdebug With Postman



In Xdebug version 2, enabling Xdebug would enable the extended stack trace for any errors, notices, or warnings written to the PHP log. With the release of version 3, this was changed so that it needs to be explicitly enabled by setting the Xdebug mode to develop. In the postman tab, click the Headers button; add a Header (on the left side), type: Cookie; add a Value (on the right side, type: XDEBUGSESSION=netbeans-xdebug; Maybe it can work wihout bringing up the debugger in another tab, by using XDEBUGSESSIONSTART=netbeans-xdebug but i didn't tested it. Debugging with Postman and PHPStorm (Xdebug) Submitted by Anonymous (not verified) on Mon, - 12:13 Postman started out as an API development tool, but has developed more into, as they put it, an 'API Development Environment'.

Postman started out as an API development tool, but has developed more into, as they put it, an 'API Development Environment'.

An over-simplified description is it allows you to create and save requests to test your API. You can then save your requests as a *collection* and share or publish them for others to use.

It supports API calls for all request types, fine control over headers, common authentication methods, and long list of other features that could fill an article... but I wanted to write specifically about using Xdebug with Postman.

How to trigger Xdebug when working with Postman

Recently, I was using Postman to troubleshoot an [API Platform](https://api-platform.com/) project and needed to trigger a Xdebug session in my IDE, [PhpStorm](https://www.jetbrains.com/phpstorm/).

Typically, I rely on a browser extension to trigger Xdebug, however Postman is its own application, so I could not rely on browser extensions.

Fortunately, there's an easy solution: Add `XDEBUG_SESSION_START=PHPSTORM` to the query string and PHPStorm will catch the debug session as it would if you were using a browser extension.

For example, if you are working on `http://localhost:8000/api/users`, simply append the URL with the query string mentioned above to initiate a debug session:

Now you can set breakpoints and debug as you would if you were working in a browser.

  • Navigation
  • Main Page
  • Community portal
  • Current events
  • Recent changes
  • Random page
  • Help
  • Toolbox
  • Page information
  • Permanent link
  • Printable version
  • Special pages
  • Related changes
  • What links here
  • 2Setup
  • 3Usage

About Xdebug

Xdebug is an opensource Debugger and Profiler for PHP. PDT has built in support for Xdebug, which allows you to step-debug through your PHP projects.


Setup


Installation

The first step is to install Xdebug and verify that Xdebug is running. See the Installation section of the Xdebug manual for how to obtain the extension.

To setup Xdebug as your default debugger in PDT, simply configure the Default Settings in the Debug eclipse preference page of PHP


Configuration

The most important setting for Xdebug to work with PDT is xdebug.remote_enable = 1. Typically you set this value in your php.ini. To verify that Xdebug

is loaded by your server, use the phpinfo() method and check if you can find an Xdebug configuration section.

With


Usage

Xdebug postman


The following examples assume you're debugging on a local mashine, not a remote server.


Debugging using the default DocumentRoot (http://localhost)

PDT provides a preference dialog to configure different PHP servers.

Each server has has a Base URL and a Local Web Root property.

When you start a debug session, the Base URL is used in conjunction with the path of the script you're debugging to determine the absolute URL to open. For example, when you debug

the script index.php in the root of your Project with the default PHP Server, PDT will launch a debug session in a browser with the URL http://localhost/index.php.

If the Local Web Root property of a server is set, you can choose the Server as the base-directory in the New PHP Project dialog (see screenshot below).


Typically you will set the Local Web Root of the default PHP server (http://localhost) to the DocumentRoot of your local Web server (e.g. apache).

The default PHP server is http://localhost and has no Local Web Root set. So the first thing to do is to open the PHP Servers preference page, and set the Local Web Root to the DocumentRoot

of your webserver (e.g. /var/www/htdocs).localhost


When creating a new PHP project, you will now see a 3rd option named Create project on local server. The new project will be created in a subfolder of the Local Web Root of the selected server, not

in the default workspace path:


Now let's create a new empty PHP project named 'MyProject' in the default PHP server and a simple index.php in the root of the project. To debug your script, all you need to do is right-clicking the index.php file and select Debug as -> PHP Web Application.

This will launch the default workbench browser with the URL http://localhost/MyProject/index.php and stop at the first line index.php (this is configurable via the Debug configuration):


You can set a breakpoint in the editor on any line by double clicking on a line number on the left.


Use Step Into (F5), Step Over (F6), Step Out (F7) or Resume (F8) to go through your scripts step by step.


Notice that the debugging session will still be open after pressing F8 (Resum), so you simply need to refresh the browser to restart debugging your script.


Xdebug With Postman Extension

Postman

Debugging using VirtualHosts (http://myProject.local)

If you're using VirtualHosts for your local project, you need to configure a PHP Server first. This server simply needs to have the correct URL to your project, and the path to the Document root (Preferences -> PHP -> PHP Servers):

With



After you've setup the PHP server, you can create a new debug configuration (Run -> Debug Configurations -> PHP Web Application) using the newly created server:



Now you can simply click 'Debug' and the debug session should open in your browser.

Xdebug With Postman Download


Choosing the browser to use for debugging

By default, eclipse launches the debug session inside the internal browser. It is recommended to use an external browser though. You can specify the browser to use in the general preferences:

Perspectives

Eclipse may be configured to open the Debug perspective automatically or to get back to the PHP perspective automatically, but not both (see bug 46336).

Xdebug With Postman Free

Retrieved from 'https://wiki.eclipse.org/index.php?title=Debugging_using_XDebug&oldid=434989'