IIS 7.x FastCGI 运行 PHP的配置方法
实际上从微软提供 FastCGI 支持以来,在 IIS官方站点上就一直有关于如何配置 IIS 各个版本下的 FastCGI 支持以及使用 FastCGI 方式运行 PHP 的详细教程
所以早在 IIS 7.0 刚刚出现没多久,微软就已经提供了在 IIS 上运行 PHP 的一种更优化的方式—— FastCGI。但是直到 IIS 7.5 随着 Windows 7 出现,网上还有很多的“大虾”在教菜鸟们如何在 IIS 7.x 下用配置ISAPI支持的方式(甚至是PHP手册上不推荐的拷贝文件到系统目录的方式)来支持 PHP。本文介绍一下在 IIS7.x 中启用 FastCGI,以及配置 PHP 的方法。
我的配置环境是 Windows 7 x86 + IIS 7.5,但是本文的内容在IIS7.x 版本中应该是完全通用的,因为 FastCGI 正是从 IIS 7.0 开始成为内置组件的。至于之前的版本,需要额外安装 FastCGI 支持,配置上也略有不同。
I. 启用 IIS 7.x 中的 FastCGI 支持
依次打开 (控制面板 | 程序和组件 | 开启或关闭Windows功能)或者直接运行optionalfeatures.exe,然后按下图所示启用 FastCGI (勾选 CGI 将同时启用 CGI 和 FastCGI 支持)。其它项你应该根据自己的需要选择。
Ⅱ安装和配置PHP
微软官方文章里建议使用非安全线程版本的PHP(non-thread safe build of php),但是由于该版本下的Zend Optimizer的启用会比较复杂,而大部分商业PHP程序都是离不开Zend Optimizer的,所以建议仍然采用安全线程版本的PHP。请从 PHP官方网站 下载最新版本的 PHP Zip格式压缩包,本文写作时使用的是 PHP 5.3.1 版.
下载以后,将其解压缩到任意目录(本文中使用 D:\phpev\php5.3_vc9),然后将目录中的 php.ini-recommend 改名为 php.ini 。用任意的文本编辑器打开这个文件,查找并确认以下设置:
fastcgi.impersonate = 1
cgi.fix_pathinfo=1
cgi.force_redirect = 0
extension_dir = "./ext"
注意:以往版本中这里往往要使用绝对路径,但是现在可以用这样的方式进行通用配置。
删除你需要激活的php扩展加载项前面的分号
例如:
extension=php_mssql.dll
extension=php_mysql.dll
注意:不是所有的项目都可以激活的,最好只激活你用到的,如果激活某一项之后运行不了,请重新注释掉该项并重启IIS。
设置完毕以后,可以启动一个命令提示行窗口(cmd.exe),运行 php –info 检查一下 php 是否可以正确运行,如果正确,会输出一系列的环境变量提示等。
III. 配置 IIS 处理 PHP 请求
运行 inetmgr打开 IIS 管理器,左边选择你的计算机,中间窗口点击“处理程序映射”,然后在右边点击“添加模块映射”。
在弹出的对话框中,按照下图填写一项请填写你自己的安装路径,即 php-cgi.exe:
填写好之后,点 确定,会弹出一个确认对话框,问你是不是真的要添加这个模块映射。点是继续。
到此就完成了 PHP 在 IIS 7.x 下的安装,在你的网站目录下创建一个文本文件,文件名后缀为.php,比如test.php,该文件的内容只有一行:
<?php phpinfo(); ?>
然后用浏览器浏览这个文件(通常是http://localhost/test.php),正常情况下,就会看到PHP的默认信息页面
注意上边高亮显示,我因为没有安装vc + 2008,没有显示这个页面卡了我一个多小时,希望大家看到这篇文章后能够节省点时间来学习php。