PHP development environment
The PHP development environment includes a PHP engine, a web server, and a database server—the so-called AMP (Apache, MySQL,PHP) technology stack that can be installed as a preconfigured package (like XAMPP for Windows or MAMP for macOS) or manually to the local operating system, in a virtual machine, or in a Docker container.
PhpStorm integrates with your PHP development environment for running, debugging, or unit testing the applications opened in the IDE.
Configure the PHP interpreter in PhpStorm as described in Configure local PHP interpreters or Configure remote PHP interpreters.
Configure integration with the database server as described in Create a data source.
Set up a debugging engine as described in Debug with PhpStorm: Ultimate Guide.
Set up a testing framework as described in Testing.
Set up the required command-line tools as described in PHP command line tools.
MAMP is the macOS package comprising Apache HTTP server, MySQL database, PHP interpreter, and some libraries. The word "MAMP" is an acronym, where "M" stands for "Macintosh", meaning it's designed for macOS, and the other letters stand for the package components.
MacOS comes with the pre-installed PHP interpreter and Apache server, which can be configured to work well together following the tutorial published by php.net. PhpStorm-related configuration is similar to the one described in this tutorial. Since installing additional packages and configuring the system environment on your own can be tricky, this guide describes how to get everything set up at once easily in a separate environment with complete MAMP package.
MAMP is a reliable and fast way to set up an environment for PHP programming. It provides all the components required for developing, running, debugging, and unit testing of PHP applications. MAMP is a good alternative to installing and configuring a Web server, a PHP engine, a database server, and a debug engine separately. To start developing, you will only need to download and install MAMP, and start the components using the MAMP control panel. >
Download and install MAMP from the MAMP Downloads page. Once the MAMP archive is downloaded, unpack it and run the installer. The MAMP installation wizard is pretty straightforward, you only need to proceed through the installation steps.
Having installed MAMP and launched its components, we now need to tell the IDE where these components are stored and how they are configured.
After installation, use the MAMP Control Panel to perform such actions as starting or stopping servers and changing configurations. The MAMP Control Panel application can be found in the Applications/MAMP folder.
To start the Apache and MySQL servers, click the Start Servers button.
data:image/s3,"s3://crabby-images/c1a41/c1a4102c73832062704759fbc5b09ea12d5b07a0" alt="Start servers Start servers"
The icons in the top-right corner will become green-colored. Once the servers are started, you can stop them at any time by clicking the Stop Servers button.
data:image/s3,"s3://crabby-images/02e6b/02e6b7d99b85e9de7790653f6ee696867a1b3782" alt="Started servers Started servers"
The Start Page (http://localhost:8888
data:image/s3,"s3://crabby-images/0054a/0054aa250dbda29bcc02d5db92a3e4085a698174" alt="MAMP start page MAMP start page"
To configure MAMP, click the Preferences... button.
data:image/s3,"s3://crabby-images/337d9/337d9bca584f6537dc3261a9242ce0c99d240781" alt="Configure MAMP servers Configure MAMP servers"
Several options are available:
Modify the Start/Stop Servers configuration on the Start/Stop tab.
Specify the Apache and MySQL ports on the Ports tab.
Specify the PHP version and caching options on the PHP tab.
Set the web server document root on the Web Server tab.
Let's start by registering the PHP executable from MAMP in PhpStorm. In the Settings dialog (CtrlAlt0S), navigate to PHP.
data:image/s3,"s3://crabby-images/a1f69/a1f690d2f58b1428b5116e85549188b34ceaf538" alt="MAMP PHP settings MAMP PHP settings"
With PhpStorm, we can have several separate PHP interpreters registered in the IDE, depending on the PHP version or PHP configuration needed for the project. All currently registered installations of PHP interpreters are displayed in the CLI Interpreter list:
data:image/s3,"s3://crabby-images/9599e/9599eb629149cfd9a19423a2906d174cbceeceef" alt="CLI interpreters list CLI interpreters list"
Click
to the right of the list. The CLI Interpreters dialog opens.
In the left-hand pane, click the
button on the toolbar.
In the Name field, type the name to identify the current installation, for example MAMP PHP 7.1.
In the PHP executable field, specify the folder where the php (PHP executable) file is stored. Either enter the path manually or click
and locate the file.
PhpStorm checks whether the specified folder contains a PHP executable file, detects the PHP version, and displays it in the PHP Info read-only field. PhpStorm also validates that the debugger is configured correctly.
We can now save these settings and select the newly added PHP interpreter for our project:
data:image/s3,"s3://crabby-images/00bc4/00bc405c7183551b5753940416ab839d3165fc19" alt="MAMP interpreter selected MAMP interpreter selected"
PhpStorm will now use the PHP installation that was bundled with MAMP.
PhpStorm offers a powerful debugger in which breakpoints can be set and variables can be inspected at runtime. For more information about using PhpStorm's debugger, refer to Debug with PhpStorm: Ultimate Guide.
Note that if you are using the latest MAMP PRO, the httpd.conf, php.ini and my.cnf files should be edited through the Template Editor provided by MAMP PRO. To edit the template files, navigate to File | Edit Template. When MAMP PRO starts the Apache and MySQL servers it uses these templates to create httpd.conf and php.ini files, erasing the previously created ones.
Once you have installed and configured the debugger, you can validate your debugging configuration by performing the steps described in Validate the configuration of a debugging engine.
Interaction between PhpStorm with Web, FTP, and other servers is handled by the FTP/SFTP/WebDAV Connectivity plugin, which is enabled by default. The IDE accesses servers using the connection settings specified in the registered server access configurations.
In the Settings dialog (CtrlAlt0S), click Deployment under Build, Execution, Deployment.
Click the
on the toolbar, select the Local or mounted folder, and specify the name for the MAMP in the dialog that opens.
After clicking OK, we can specify the path of the Apache's web root
/Applications and the URL of the web server, http://localhost:8888. Note that the actual settings depend on how you have configured the MAMP Apache server in the MAMP configuration or Apache configuration files./MAMP /htdocs Don't forget to mark the server as default by clicking
, so that PhpStorm uses it with browser integration instead of the built-in web server. By clicking Open, we can open the MAMP htdocs folder in the browser and thus verify that the provided settings are correct.
PhpStorm allows to connect to the MAMP MySQL database server using the Database Tools and SQL plugin, which is installed and enabled by default. Before you start, make sure that the MySQL server is running on the MAMP PRO Control Panel. If you are using MAMP PRO, also make sure that the Allow network access to MySQL checkbox is selected on the MAMP PRO Control Panel.
data:image/s3,"s3://crabby-images/ed0a3/ed0a3be360b8f65d04ece48b6a8003d0665dc965" alt="MAMP SQL server running MAMP SQL server running"
From the right-hand side of the IDE, open the Database tool window.
data:image/s3,"s3://crabby-images/faed8/faed80b7f4897fd3448573ad0b8aa290d0aa62f4" alt="Open the Database tool window Open the Database tool window"
Here, we can create a new connection or Data Source by using the context menu or the toolbar button. We need to specify the JDBC database driver that will be used to connect to our database. For MySQL, we can use the MySQL Connector driver available in the list of drivers. PhpStorm doesn't ship these drivers but we can download the correct JDBC driver by clicking link.
Next, we need to enter the connection details. Alternatively, we can provide the connection string to the MySQL Database in the Database URL field, for example jdbc:mysql:
We can also specify the username and password for MySQL. By default, MAMP uses root both as the username and the password.
When using UTF-8 or unicode characters in the username, password or database name, two additional parameters must be added to the connection string: characterEncoding
and useUnicode
. An example connection string would be jdbc:mysql://localhost:8889?characterEncoding=utf8&useUnicode=true
. It may also be required to select a different JDBC driver from the list, that is, com.mysql.jdbc.NonRegisteringDriver
.
Having defined the data source, use the Test Connection button to verify the settings and make sure PhpStorm can connect to MySQL.
data:image/s3,"s3://crabby-images/ade5e/ade5eb53134043dca599099580976f17a92307df" alt="Data source properties Data source properties"
We can now create tables, run queries, update data and so on. For more information, refer to Database Tools and SQL.
XAMPP is a cross-platform package consisting of an Apache HTTP server, MySQL database, PHP interpreter, and Perl interpreter. The word "XAMPP" is an acronym, where "X" stands for "cross", meaning "cross-platform", and the other letters stand for the package components.
XAMPP is a reliable and fast way to set up an environment for PHP programming. It provides all the components required for developing, running, debugging, and unit testing of PHP applications. XAMPP is a good alternative to installing and configuring a Web server, a PHP engine, a database server, and a debug engine separately. To start developing, you will only need to download and install XAMPP, and start the components using the XAMPP control panel.
warning
If you are using Windows Vista, avoid installing the package in the Program Files folder. This folder is write-protected by default, which means that no files can be placed on the server and further processed by the PHP engine.
Download and install XAMPP from the XAMPP Downloads page. Once the XAMPP archive is downloaded, unpack it and run the installer. The XAMPP installation wizard is pretty straightforward, you only need to proceed through the installation steps.
Having installed XAMPP and launched its components, we now need to tell the IDE where these components are stored and how they are configured.
After installation, use the XAMPP Control Panel to perform such actions as starting or stopping servers and changing configurations.
To start a specific server, click the Start button next to it.
data:image/s3,"s3://crabby-images/fb869/fb86926bde55bab9e21daa81d3ec761d768a56cf" alt="Staring XAMPP servers Staring XAMPP servers"
By default, none of the servers such as Apache or MySQL are installed as Windows Services. This means that whenever we want to make use of these servers, we have to manually start them through the XAMPP Control Panel. When a server runs as a Windows Service, it with Windows automatically.
Open the XAMPP Control Panel as an administrator.
Stop the server you want to install as a Windows Service by clicking the Stop button.
Click X next to the server and confirm the service installation. Once the installation succeeds, a green checkmark will be displayed next to the server, indicating the server is now running as a Windows Service.
Let's start by registering the PHP executable from XAMPP in PhpStorm. In the Settings dialog (CtrlAlt0S), navigate to PHP.
data:image/s3,"s3://crabby-images/0b280/0b280805229cee45ee9756466ecd5fb4188346cf" alt="XAMPP php settings XAMPP php settings"
With PhpStorm, we can have several separate PHP interpreters registered in the IDE, depending on the PHP version or PHP configuration needed for the project. All currently registered installations of PHP interpreters are displayed in the CLI Interpreter list:
data:image/s3,"s3://crabby-images/0862d/0862d7a3e829c6a30451bddd54f5883e799527bf" alt="the CLI Interpreters list the CLI Interpreters list"
Click
to the right of the list. The CLI Interpreters dialog opens.
In the left-hand pane, click the
button on the toolbar.
In the Name field, type the name to identify the current installation, for example XAMPP PHP 7.2.
In the PHP executable field, specify the folder where the php (PHP executable) file is stored. Either enter the path manually or click
and locate the file.
PhpStorm checks whether the specified folder contains a PHP executable file, detects the PHP version, and displays it in the PHP Info read-only field. PhpStorm also validates that the debugger is configured correctly.
We can now save these settings and select the newly added PHP interpreter for our project:
data:image/s3,"s3://crabby-images/b855a/b855a33c50ff2e366845ad042482988758a4ac8b" alt="XAMPP interpreter selected XAMPP interpreter selected"
PhpStorm will now use the PHP installation that was bundled with MAMP.
PhpStorm offers a powerful debugger in which breakpoints can be set and variables can be inspected at runtime. For more information about using PhpStorm's debugger, refer to Debug with PhpStorm: Ultimate Guide.
Once you have installed and configured the debugger, you can validate your debugging configuration by performing the steps described in Validate the configuration of a debugging engine.
Interaction between PhpStorm with Web, FTP, and other servers is handled by the FTP/SFTP/WebDAV Connectivity plugin, which is enabled by default. The IDE accesses servers using the connection settings specified in the registered server access configurations.
In the Settings dialog (CtrlAlt0S), click Deployment under Build, Execution, Deployment.
Click
on the toolbar, select the Local or mounted folder, and specify a name for the XAMPP server.
After clicking OK, we can specify the path of the Apache's web root C:
\xampp and the URL of the web server, http://localhost. Note that the actual settings depend on how you have configured the XAMPP Apache server through the C:\htdocs \xampp configuration file.\apache \conf \httpd.conf Don't forget to mark the server as default by clicking
, so that PhpStorm uses it with browser integration instead of the built-in web server.
By clicking Open, we can open the MAMP htdocs folder in the browser and thus verify that the provided settings are correct.
PhpStorm allows you to connect to the XAMPP MySQL database server using the Database Tools and SQL plugin, which is installed and enabled by default. Before you start, make sure that the MySQL server is running on the XAMPP Control Panel.
From the right-hand side of the IDE, open the Database tool window.
data:image/s3,"s3://crabby-images/55acc/55accc49f0cb684440da8d68385bd04e9a7d3c7b" alt="Open the Database tool window Open the Database tool window"
Here, we can create a new connection or Data Source by using the context menu or the toolbar button. We need to specify the JDBC database driver that will be used to connect to our database. For MySQL, we can use the MySQL Connector driver available in the list of drivers. PhpStorm doesn't ship these drivers, but we can download the correct JDBC driver by clicking link.
Next, we need to enter the connection details. Alternatively, we can provide the connection string to the MySQL Database in the Database URL field, for example jdbc:mysql:
Note that it is recommended to change the default MySQL username and password after installing XAMPP, which can be done on the http://localhost/security/xamppsecurity.php page.
We can also specify the username and password for MySQL. By default, XAMPP uses root as the username, and a blank password.
When using UTF-8 or unicode characters in the username, password or database name, two additional parameters must be added to the connection string: characterEncoding
and useUnicode
. An example connection string would be jdbc:mysql://localhost:8889?characterEncoding=utf8&useUnicode=true
. It may also be required to select a different JDBC driver from the list, that is, com.mysql.jdbc.NonRegisteringDriver
.
Having defined the data source, click the Test Connection button to verify the settings and make sure PhpStorm can connect to MySQL.
data:image/s3,"s3://crabby-images/9bf79/9bf79ae4dccf46346bc0448dc4b1720e85974bdb" alt="Data source properties Data source properties"
We can now create tables, run queries, update data and so on. For more information, refer to Database Tools and SQL.
Thanks for your feedback!