PHP IIS 7和FastCGI不工作


PHP IIS 7 and FastCGI not working

我遵循这里的说明:使用FastCGI托管PHP应用程序在IIS 7上配置Windows 2008, PHP与IIS 7和FastCGI,我遇到了问题。PHP版本为5.3.8。我已经在IIS上设置了处理程序映射,并创建了一个测试页面,尽管该页面除了500错误之外没有返回任何内容。我确保PHP可以正常工作,从命令行输入

时,我得到一个响应:
php -version.
也就是说,我已经为php页面打开了失败请求跟踪规则,当我浏览错误日志时,我看到如下内容:
<EventData>
  <Data Name="ContextId">{00000000-0000-0000-0200-0080010000F6}</Data>
  <Data Name="ModuleName">FastCgiModule</Data>
  <Data Name="Data1">FASTCGI_RESPONSE_ERROR</Data>
  <Data Name="Data2">PHP Warning:  phpinfo() [&lt;a href=&apos;function.phpinfo&apos;&gt;function.phpinfo&lt;/a&gt;]: It is not safe to rely on the system&apos;s timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected &apos;America/New_York&apos; for &apos;-4.0/DST&apos; instead in C:'inetpub'wwwroot'phpinfo.php on line 1
</Data>
<Data Name="ErrorCode">5</Data>
 </EventData>
 <RenderingInfo Culture="en-US">
  <Opcode>MODULE_WARNING</Opcode>
  <Keywords>
  <Keyword>Module</Keyword>
  </Keywords>
  <freb:Description Data="ErrorCode">Access is denied.
 (0x5)</freb:Description>

从失败请求日志的顶部,我可以看到它在IUSR帐户下运行:

tokenUserName="NT AUTHORITY'IUSR"

fastCgi的设置:

<fastCgi>
    <application fullPath="C:'PHP'php-cgi.exe" instanceMaxRequests="10000">
        <environmentVariables>
            <environmentVariable name="PHP_FCGI_MAX_REQUESTS" value="10000" />
            <environmentVariable name="PHPRC" value="C:'php'php.ini" />
        </environmentVariables>
    </application>
</fastCgi>
<handlers accessPolicy="Read, Script">
    <add name="PHP via FastCGI" path="*.php" verb="*" modules="FastCgiModule" scriptProcessor="C:'PHP'php-cgi.exe" resourceType="Unspecified" requireAccess="Script" />

我已经确保这个用户名完全控制我的C:'PHP目录。我的PHP .ini文件配置在C:'PHP目录下。

除了遵循那篇文章中的说明之外,我还尝试为PHP创建一个脚本映射,当我创建它时,我得到了一个差异错误,而不是500。

HTTP Error 403.1 - Forbidden
You have attempted to run a CGI, ISAPI, or other executable program from a directory that does not allow executables to run.

再说一次,IUSR对这个目录有完全的控制,所以我不太明白为什么会出现这个错误信息。

这个问题在日志中对我很明显。我忽略了关于日期的PHP警告。认为这只是一个警告。我将它设置为:

date.timezone = America/New_York

为将来参考,您可以使用http://php.iis.net/轻松地将php安装到IIS设置中。它带有一个管理器,可以让你进入"开发模式",显示php错误,而不是掩盖错误。