To host a PHP application on a windows server follow these steps
Install IIS on windows server
On Windows Server 2012 machine
Install PHP
using Web Platform Installer (Web PI)
Download and install php
Install IIS on windows server
On Windows Server 2012 machine
- On the Start page, click the Server Manager tile, and then click OK.
- In Server Manager, select Dashboard, and click Add roles and features.
- In the Add Roles and Features Wizard, on the Before You Begin page, click Next.
- On the Select Installation Type page, select Role-based or Feature-based Installation and click Next
- On the Select Destination Server page, select Select a server from the server pool, select your server, and click Next.
- On the Select Server Roles page, select Web Server (IIS), and then click Next.
- On the Select Features page, note the preselected features that are installed by default, and then select CGI. This selection also installs FastCGI, which is recommended for PHP applications.
- Click Next.
- On the Web Server Role (IIS) page, click Next.
- On the Select Role Services page, note the preselected role services that are installed by default, and then click Next.
- On the Confirm Installation Selections page, confirm your selections, and then click Install.
- On the Installation Progress page, confirm that your installation of the Web Server (IIS) role and required role services completed successfully, and then click Close.
- To verify that IIS installed successfully, type the following into a web browser:
http://localhost or http://127.0.0.1
You should see the default IIS Welcome page.
On Windows 8 machine
- On the Start page, type Control Panel, and then click the Control Panel icon in the search results.
- In Control Panel, click Programs, and then click Turn Windows features on or off.
- In the Windows Features dialog box, click Internet Information Services, note the preselected features that are installed by default, and then select CGI. This selection also installs FastCGI, which is recommended for PHP applications.
- Click OK.
- To verify that IIS installed successfully, type the following into a web browser:
http://localhost
You see the default IIS Welcome page.
using Web Platform Installer (Web PI)
- Open a browser to the following website: Microsoft Web Platform Installer 3.0.
- Click Download It Now, and then click Run.
- At the top of the Web Platform Installer window, click Products.
- Click Frameworks, and then select the current version of PHP. (At this writing, the current version is PHP 5.3.13.)
- Click Install.
The Web Platform Installation page displays the version of PHP and its dependencies that will be installed. - Click I Accept.
Web PI installs the PHP packages. - Click Finish.
- Download PHP and the WinCache extension.
- Install PHP and WinCache.
- Add the PHP installation folder to the Path environment variable.
- Set up a handler mapping for PHP.
- Add default document entries for PHP.
- Test your PHP installation.
Download and install php
- Open your browser to Windows for PHP Download Page and download the PHP 5.3 non-thread-safe zip package.
Caution The PHP 5.4 version does not work with the WinCache extension version 1.1. Use PHP 5.3 until this problem is resolved. - Download the WinCache extension (Php_wincache-svn20110402-5.2-nts-vc6-x86.zip) from the List of Windows Extensions for PHP.
- Extract all files in the PHP .zip package to a folder of your choice, for example C:\PHP\.
- Extract the WinCache .zip package to the PHP extensions folder (\ext), for example C:\PHP\ext.
The WinCache .zip package contains one file (Php_wincache.dll). - Open Control Panel, click System and Security, click System, and then click Advanced system settings.
- In the System Properties window, select the Advanced tab, and then click Environment Variables.
- Under System variables, select Path, and then click Edit.
- Add the path to your PHP installation folder to the end of the Variable value, for example ;C:\PHP. Click OK.
- Open IIS Manager, select the hostname of your computer in the Connections panel, and then double-click Handler Mappings.
- In the Action panel, click Add Module Mapping.
- In Request path, type *.php.
- From the Module menu, select FastCgiModule.
- In the Executable box, type the full path to Php-cgi.exe, for example C:\PHP\Php-cgi.exe.
- In Name, type a name for the module mapping, for example FastCGI.
- Click OK.
- Select the hostname of your computer in the Connections panel, and double-click Default Document.
- In the Action panel, click Add. Type Index.php in the Name box, and then click OK.
- Click Add again. Type Default.php in the Name box, and then click OK.
- Open a text editor, for example Notepad, as Administrator.
- In a new file, type the following text:
- Save the file as C:\inetpub\wwwroot\Phpinfo.php.
- Open a browser and enter the following URL: http://localhost/phpinfo.php
A nicely formatted webpage is displayed showing the current PHP settings.
Add php application
Once you have IIS and PHP installed, you can add a PHP application to your web server. This section describes how to set up your PHP application on an IIS web server with PHP installed. It does not explain how to develop a PHP application.
- Open IIS Manager.
- For Windows Server 2012, on the Start page click the Server Manager tile, and then click OK. On the Server Manager Dashboard, click the Tools menu, and then click Internet Information Services (IIS) Manager.
- For Windows 8, on the Start page type Control Panel, and then click the Control Panel icon in the search results. On the Control Panel screen, click System and Security, click Administrative Tools, and then click Internet Information Services (IIS) Manager.
- In the Connections pane, right-click the Sites node in the tree, and then click Add Website.
- In the Add Website dialog box, type a friendly name for your website in the Site name box.
- If you want to select a different application pool than the one listed in the Application Pool box, click Select. In the Select Application Pool dialog box, select an application pool from the Application Pool list and then click OK.
- In the Physical path box, type the physical path of the website's folder, or click the browse button (...) to navigate the file system to find the folder.
- If the physical path that you entered in step 5 is to a remote share, click Connect as to specify credentials that have permission to access the path. If you do not use specific credentials, select the Application user (pass-through authentication) option in the Connect As dialog box.
- Select the protocol for the website from the Type list.
- The default value in the IP address box is All Unassigned. If you must specify a static IP address for the website, type the IP address in the IP address box.
- Type a port number in the Port text box.
- Optionally, type a host header name for the website in the Host Header box.
- If you do not have to make any changes to the site, and you want the website to be immediately available, select the Start Web site immediately check box.
- Click OK.
configure wincache
Configure other PHP settings
To configure the WinCache PHP extension
- In Windows Explorer, open your PHP installation folder, for example C:\PHP.
- Choose either the php.ini - development or php.ini - production file, and rename it php.ini.
- In a text editor, open the php.ini file and added the following line at the end of the file: extension = php_wincache.dll.
- Save and close the php.ini file.
- Recycle the IIS Application Pools for PHP to pick up the configuration changes.
To view WinCache configuration and other PHP settings
- Open a text editor.
- In a new file, type the following text:
- Save the file as c:\inetpub\wwwroot\phpinfo.php.
- Open a browser and enter the following URL: http://localhost/phpinfo.php
A nicely formatted web page is displayed showing the current PHP settings. The WinCache settings appear in a section called wincache.
Warning |
---|
Delete the phpinfo.php file when it’s no longer needed. |
Configure other PHP settings
To configure a PHP setting
- In Windows Explorer, open your PHP installation folder, for example C:\PHP.
- In a text editor, open the php.ini file.
- Search the file for the setting you want to change.
If the setting is commented out (line begins with a semicolon [;]), delete the semicolon and set the value. If you can’t find the setting, add the line to the end of the file. - Save and close the php.ini file.
- Recycle the IIS Application Pools for PHP to pick up the configuration changes.
configure PHP extensions
configure PHP security settings
To configure a PHP extension
- Download the PHP extension you want from the list of Windows extensions for PHP.
- Extract the extension zip package to the PHP extensions folder (\ext), for example C:\PHP\ext.
- In Windows Explorer, open your PHP installation folder, for example C:\PHP.
- In a text editor, open the php.ini file.
- Search the file for the extension you want to configure.
If the extension is commented out (line begins with a semicolon [;]), delete the semicolon. If you can’t find the extension, add it to the end of the file. A line that adds an extension is in the form: extension = extension_name.dll. For example: extension = php_soap.dll. - Save and close the php.ini file.
- Recycle the IIS Application Pools for PHP to pick up the configuration changes.
configure PHP security settings
To configure a PHP setting for security
- In Windows Explorer, open your PHP installation folder, for example C:\PHP.
- In a text editor, open the php.ini file.
- Search the file for the setting you want to change.
If the setting is commented out (line begins with a semicolon [;]), delete the semicolon and set the value. If you can’t find the setting, add the line to the end of the file. - Save and close the php.ini file.
- Recycle the IIS Application Pools for PHP to pick up the configuration changes.
Implement the following recommendations to isolate websites and web applications on your server.
- Use one application pool per website or web application.
- Limit access to site folders and files to the application pool identity.
- Set up a separate PHP temp folder per site and only give access to the application pool identity.
- Make sure to set an ACL (access control list) on each site root to allow only access to the application pool identity.
To create an application pool
- Open IIS Manager.
- In the Connections pane, click Application Pools.
- In the Actions pane, click Add Application Pool.
- In the Name box, type a unique name for the application pool.
- Under .NET Framework version, select No Managed Code.
- Select the Managed pipeline mode. The Integrated mode is recommended.
- Click OK.
To move an application to another application pool
- Open IIS Manager.
- In the Connections page, select the website or web application you want to move.
- In the Actions pane, click Basic Settings.
- On the Edit Site dialog, click Select to open the Select Application Pool dialog, and then select the application pool from the Application pool menu.
- Click OK to close the Select Application Pool dialog, and click OK to close the Edit Site menu.
To add an application pool identity to a folder or file ACL
- Open Windows Explorer and navigate to the folder or file.
- Right click the folder or file, and then click Properties.
- Select the Security tab, and then click Edit.
- Click Add, click Locations, and select your server as the location to search.
- In the Enter the object names to select box, type IIS APPPOOL\applicationPoolName, where applicationPoolName is the application pool identity.
- Click OK, click OK, and click OK again to close the dialogs.
When you have multiple PHP applications on an IIS web server, you can improve security by configuring a PHP process pool and a php.ini file for each application. This section explains how to configure process pools and multiple pnp.ini files by using an applicationHost.config file.
When each website has its own application pool, which is a recommended practice on IIS, it is possible to associate a dedicated FastCGI process pool with each website. This association is done in the fastCgi section of the applicationHost.config file. A FastCGI process pool is uniquely identified by the combination of fullPath and arguments attributes of the application element. To create several FastCGI process pools for the same process executable, such as php-cgi.exe, use the arguments attribute to distinguish the process pool definitions. With php-cgi.exe processes, use the command line switch "-d" to define an INI entry for a PHP process. And use this switch to set a PHP setting that makes the arguments string unique.
For example, if there are two Web sites "website1" and "website2" that must have their own set of PHP settings, define the FastCGI process pools as follows:
In this example the PHP setting open_basedir is used to distinguish between the process pool definitions. The setting also enforces that the PHP executable for each process pool can perform file operations only within the root folder of the corresponding website.
Therefore, the PHP handler mapping for website1 is as follows:
And the handler mapping for website2 is as follows:
For example, if there are two Web sites "website1" and "website2" that must have their own set of PHP settings, define the FastCGI process pools as follows:
In this example the PHP setting open_basedir is used to distinguish between the process pool definitions. The setting also enforces that the PHP executable for each process pool can perform file operations only within the root folder of the corresponding website.
Therefore, the PHP handler mapping for website1 is as follows:
And the handler mapping for website2 is as follows:
When the PHP process starts, it determines the location of the configuration php.ini file by using various settings. The PHP documentation provides a detailed description of the PHP startup process. One of the places where the PHP process searches for the php.ini location is the PHPRC environment variable. If the PHP process finds a php.ini file in the path that is specified in this environment variable, it will use it. Otherwise, the PHP process will revert to using the default location of the php.ini file. This environment variable can be used to allow hosting customers to use their own versions of php.ini files.
For example, if there are two websites, "website1" and "website2," that are located at the following file paths: C:\WebSites\website1 and C:\WebSites\website2, you can configure the php-cgi.exe process pools in the fastCgi section of the applicationHost.config file as follows:
This way website1 can have its own version of the php.ini file that is located in the C:\WebSites\website1, while website2 can have its own version of the php.ini file that is located in C:\WebSites\website2. This configuration also ensures that if a php.ini file cannot be found in the location that is specified by the PHPRC environment variable, then PHP will use the default php.ini file that is located in the same folder where the php-cgi.exe is located.
For example, if there are two websites, "website1" and "website2," that are located at the following file paths: C:\WebSites\website1 and C:\WebSites\website2, you can configure the php-cgi.exe process pools in the fastCgi section of the applicationHost.config file as follows:
This way website1 can have its own version of the php.ini file that is located in the C:\WebSites\website1, while website2 can have its own version of the php.ini file that is located in C:\WebSites\website2. This configuration also ensures that if a php.ini file cannot be found in the location that is specified by the PHPRC environment variable, then PHP will use the default php.ini file that is located in the same folder where the php-cgi.exe is located.