WARNING
Aparche is really the best way to go when using CakePHP. But if you simply have to use IIS then continue reading. Also, It goes without saying I take no responsibility for any problems you might run into by following this guide. The information is provided as is for informational purposes only.
Lets get down to business
I'll be showing you how to do this using the free / lite version of the program to get CakePHP up and running presuming that you have ISS and PHP configured and running correctly (make sure that PHP is using ISAPI not CGI).
From http://www.helicontech.com/,
"ISAPI_Rewrite Lite is completely free and it is a good solution for development or testing purposes and for small servers that host only a few web sites and don’t require distributed configurations or proxy functions."
If your willing to pay you can get the premium version of "ISAPI_Rewrite" which, according to helicontech, should provide support for CakePHP's .htaccess files.
http://www.helicontech.com/isapi_rewrite/
You can download the lite version and full version here:
http://www.helicontech.com/download-isapi_rewrite3.htm
Configuring ISS
Configure ISS to not check the existance of scripts in PHP.
From http://http//www.dustinweber.com/cakephp/cakephp-on-iis-troubleshooting-help-guide/
1) Go to your server admin panel, right-click on the web server (ex: Default Web Site) and click on properties.
2) Go to the Home Directory tab at the top and click on the Configuration button near the bottom of that page.3) Find the .php extension listed in the “Application Configuration” page that appears; click on the .php extension and then click the edit button near the bottom of the page.
4) You should be on the “Add/Edit Application Extension Mapping” page: simply uncheck the “Check that file exists” box at the bottom of the page.
5) Click OK, Click OK again, Click OK once more (you should’ve closed all the windows).
6) Now restart IIS (command prompt -> IISReset).
- Double check your security permissions for the Cake folders/files you dropped into your web root. Just remember that something unzipped to the desktop and copied into your Inetpub directory will often have security permissions that will prevent the server from accessing some files properly.
- Remember that the app/temp folder must be writeable by the web server (for caching). That particular problem had me scratching my head once or twice.
Also make sure that index.php is set to load automatically as first preferrence.
Installing CakePHP & setting permissions
Get a copy of CakePHP from http://cakephp.org/ and extract it into your site. Set the webroot (cake\app\webroot) folder inside the cake as the default web directory (not wwwroot) from the properties box in your website in the ISS Management page.
Make sure that your cake\app\tmp folder has write permissions set.
Installing and Configuring ISAPI_Rewrite 3 Lite
Because the lite version of ISAPI_Rewrite doesn't allow for multiple varying .htaccess files a general configuration must be set.
Download ISAPI_Rewrite 3 Lite from:
http://www.helicontech.com/download-isapi_rewrite3.htm
-Run the installer
-access the "ISAPI_Rewrite Manager" from the start menu and click edit
-paste in this:
# Helicon ISAPI_Rewrite configuraion file-click apply in the window and then apply again.
# Version 3.0.0.28
RewriteEngine on
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?url=$1 [L,QSA]
And Finally...
Test to see if your hard work has payed off.
Point your browser to the homepage of your website ie. http://www.example.com/
everything should be working as in apache!
feel free to leave a comment about any improvements or questions you may have
Note: if you get "Permission denied in ...\cake\libs\file.php on line 292" or "cake [function.unlink]: permission denied in file.php" it means your tmp file has not been given write permissions. Make sure this is set.
Sources:
http://www.helicontech.com/
http://www.dustinweber.com/cakephp/cakephp-on-iis-troubleshooting-help-guide/
http://blog.localkinegrinds.com/2006/07/28/cakephp-and-iis-solved/
http://bakery.cakephp.org/articles/view/clean-urls-with-isapi-rewrite-on-iis