As everyone knows, PHP is one of the most used server side languages on the web, and Windows is the dominating operating system for desktop PCs. So I think that a quick summary on how to configure a PHP development environment in Windows could be useful. In this post we will use the last version of Windows: Windows 10.
IIS installation
By default, IIS (Internet Information Services, that is Microsoft’s web server software) is not installed. So the first step is to install it.
To do that, open the Window’s control panel and click on “Programs and feature”:
data:image/s3,"s3://crabby-images/47cf2/47cf22fab100cf4f373e2455b83fe4c0b35cfe1c" alt="Windows Control Panel"
You will see the list of the currently installed programs on your PC. Click on “Turn Windows features on or off”.
data:image/s3,"s3://crabby-images/60f78/60f7840ba217d022bae6d1b6c1c2ea9349df6223" alt="Programs and Features"
A new window will appear with a list of Windows features that you can select. You can see in the red box the elements I have selected for the installation. To use PHP is important that you select “CGI”.
data:image/s3,"s3://crabby-images/95ba8/95ba81512c386ec05770a30d08849e9682243af0" alt="Windows Features"
Now press “OK” to proceed with the installation.
PHP installation
To install the PHP runtime you could refer to this link from Microsoft:
In any case here are the necessary steps and some screenshot that should help for your installation.
First of all, download the zip containing the PHP runtime. You can download at this URL:
https://windows.php.net/download/
Below is an excerpt from the web page. In this moment, the latest version of PHP is 7.4.9, so we will download that version. Note that you have to choose the “Non Thread Safe” version. Click on the “Zip” link to download.
data:image/s3,"s3://crabby-images/d4062/d406240a99d968fdb6afb12a751a889443a72928" alt="PHP runtime download"
When the download is completed, extract the zip in the folder “C:\php_7_4_9” (or whatever folder you prefer). Remember to rename the file “php.ini-development” in “php.ini”.
Now we have to put the folder we just created in the “PATH” environment variable. To do that, follow these steps:
Open Windows control panel again, and this time click on “System”:
data:image/s3,"s3://crabby-images/5cb95/5cb9509ff6e233987427c15ed1e5b8f4a4dc8bc7" alt="Windows control panel (again...)"
You will see the following window, where you have to click on “Advanced system setting”.
data:image/s3,"s3://crabby-images/46a3a/46a3a697429596ea81b5cb232229486687b24c48" alt="Windows System"
The “System properties” window will appear:
data:image/s3,"s3://crabby-images/8f6c1/8f6c19c69a5f5e1fef5e1243d9340d354f5b1d24" alt="Windows System Properties"
Now click on the button “Environment variables…” to show the following window:
data:image/s3,"s3://crabby-images/3240e/3240ef2bea7cd1f1fe598737fcff9b6f205b3b4a" alt="Environment Variables"
In the frame “System variables” select the row containing the variable “Path” and click “Edit”. In the following window, click “New” to add a new item with the path of the php runtime. As you can see below, I have already added my path.
data:image/s3,"s3://crabby-images/e6afd/e6afdca6d3f3a9165c475a094cee5d6b2a3cc6ce" alt="Edit environment variables"
Now that you configured the environment “PATH” variable, there is one more step: IIS configuration. To complete this step, run IIS Manager. When IIS Manager is running, click on your host name (the red box on the left) and then click on “Handler Mappings” (the red box on the right).
data:image/s3,"s3://crabby-images/36c38/36c38d95ac4e44fb886ea08977dd718da355eaa3" alt="IIS Manager"
And here is the “Handler Mappings” window. Click on “Add Module Mapping…” on the right.
data:image/s3,"s3://crabby-images/2e357/2e3578486c93b6ac5f7f865b66f3ab89506b2179" alt="IIS Handler Mappings"
In the following window fill the fields as in the screenshot. Pay attention that you may have a different php runtime path. In my case is “C:\php_7_4_9”. Click “OK” to confirm.
data:image/s3,"s3://crabby-images/81e0c/81e0c6df361195b9ad2add06f16e158f1a2f6fb5" alt="Add Mapping..."
We are almost done… At this point I always prefer to restart IIS. From Windows control panel, click on “Administrative tools” and then “Services”.
data:image/s3,"s3://crabby-images/95611/95611813bbd39281323629272e176c6ba072464d" alt="Go to Windows Services"
In the list of services, look for “World Wide Web Publishing Service”, click it to select the row and from the context menu click on “Restart”.
data:image/s3,"s3://crabby-images/e5906/e5906e580be079599459f91c19646f0bdc1c9186" alt="Restart World Wide Web Publishing Service"
Now you are ready to create your first php script. With Notepad create a new text file called “test.php” with the following content:
<?php
phpInfo();
Put this file in IIS default website folder which, in my case, is “C:\inetpub\wwwroot”.
Run a browser and go to the url “http://localhost/test.php”. You should see the following:
data:image/s3,"s3://crabby-images/65c34/65c349949483af0a1c85c0c02f8e1642e13094fe" alt="Your first PHP script!"
Congratulations, you are running PHP on your Windows PC!