ASP.NET程序从IIS6移植到IIS7时出现500.22错误

今天把网站部署到海外空间,管服务器的哥们来找我.说出错了,看了下报错的提示:

 

应用程序“TTT”中的服务器错误
Internet 信息服务 
7.0
错误摘要
HTTP 错误 
500.22 - Internal Server Error
检测到在集成的托管管道模式下不适用的 ASP.NET 设置。
详细错误信息
模块    ConfigurationValidationModule
通知    BeginRequest
处理程序    StaticFile
错误代码    
0x80070032
请求的 URL    http:
//localhost:81/
物理路径    E:\TTT
登录方法    尚未确定
登录用户    尚未确定
最可能的原因:
?    此应用程序在 system.web
/httpModules 节中定义配置。
可尝试的操作:
?    将配置迁移到 system.webServer
/modules 节。也可以手动这样做,或通过在命令行中使用 AppCmd 来这样做 - 例如,%SystemRoot%\system32\inetsrv\appcmd migrate config "Default Web Site/"。使用 AppCmd 迁移应用程序将使它能够在集成模式下工作,并能继续在经典模式下和以前版本的 IIS 上工作。
?    如果您确信可以忽略此错误,则可以通过将 system.webServer
/validation@validateIntegratedModeConfiguration 设置为 false 来禁用它。
?    也可以将应用程序切换到经典模式应用程序池 
- 例如,%SystemRoot%\system32\inetsrv\appcmd set app "Default Web Site/" /applicationPool:"Classic .NET AppPool"。只有在无法迁移应用程序时才这样做。
(将“Default Web Site”和“Classic .NET AppPool”设置为您的应用程序路径及应用程序池名称)
链接和更多信息集成模式是在 IIS 
7.0 上运行 ASP.NET 应用程序的首选模式

==============================================================

查了下500.22错误:http://support.microsoft.com/kb/943891/zh-cn(IIS 7.0 中的 HTTP 状态代码)

如下:

500.22-托管管道模式不能应用一个 ASP.NET httpModules 配置。
500.23-托管管道模式不能应用一个 ASP.NET httpHandlers 配置。

 

 

再看到这篇文章很大的启示:http://www.jb51.net/article/15816.htm,其中一段描述到:

{ IIS 的应用程序池根据托管管道模式分了两种类型:集成和经典两种

集成 .NET 模式下,应用程序不应在 <system.web>/<httpModules> 配置节中指定 ASP.NET 模块组件,而应使用 <system.webServer>/<modules> 配置节来加载 ASP.NET 模块组件。

.NET 模式 则是我们以前习惯的IIS 6 的方式,没有上述限制。}

 

 

检测到在集成的托管管道模式下不适用的 ASP.NET 设置;原来海外服务器的应用程序池使用了默认的“集成模式”.

所以所有的http请求处理都托管给了IIS,我自己的配置当然就不起效了。

 

 

解决方法:

 

方法1:在IIS7上配置应用程序池.

将程序池的模式改为“经典”之后,一切正常。

(具体方法:开IIS,右边操作里选基本设置,应用程序池旁边点选择,选为Classic .net AppPool,就将管理模式切换为了经典模式就OK了)

可这是在IIS上操作,但我是租的空间,没有这个权限.

 

方法2:在IIS7添加我们的模块(modules)

参考:http://aabs.wordpress.com/2007/11/16/ihttpmodule-not-running-after-conversion-to-iis-7-and-net-35/

 

方法3:修改web.config

再细了解:

IIS7的Application Pools有两种mode,一种是Integrated,一种是classic。如果使用Integrated模式,那么对自定义的httpModules和httpHandlers就要修改配置文件了,需要将他们转移到<modules>和<hanlders>节里去。

IIS7的两种模式和IIS6有什么区别?

IIS7.0 Integrated mode:asp.net的modules和handlers从<system.webServer>下的<modules>和<handlers>里读取,以前的<system.web>下的<httpModules>和<httpHandlers>配置节会被忽略,如果设置禁止验证(disabled validation),是不会产生错误的。

IIS7.0 Classic mode:与以上情况是相反的,<modules>和<handlers>会被忽略。

IIS6.0 :这个大家都不陌生了。

如果做一个可以在IIS6和IIS7的两种mode下都可以运行的配置?validateIntegratedModeConfiguration=“false”是做什么用的?有需要的朋友可以在这里查看详情。

其次,从iis6迁移到iis7上后,有些url rewrite功能可能就不好用了,下面这篇文章讲述了一个hack方法,有效的控制了staticFile handler的职责,实现了像iis6那样的工作方式。

 示例代码:

<system.web>
   <!-- Modules for IIS 6.0 and IIS 7.0 Classic mode -->
   <httpModules>
<add name="MagicAjaxModule" type="MagicAjax.MagicAjaxModule, MagicAjax"/>
</httpModules>
   <!-- Handlers for IIS 6.0 and IIS 7.0 Classic mode -->   

    <httpHandlers>

      <add path="*.myh" verb="GET" type="MyApp.MyHandler" />

    </httpHandlers

 

</system.web>
<system.webServer>

  <!-- Modules for IIS 7.0 Integrated mode -->
<modules>
<add name="MagicAjaxModule" type="MagicAjax.MagicAjaxModule, MagicAjax"/>
</modules>

  <!-- Handlers for IIS 7.0 Integrated mode -->   

   <handlers>

      <add name="MyHandler" path="*.myh" verb="GET" type="MyApp.MyHandler" preCondition="integratedMode" />      

    </handlers>

 <!-- Disable detection of IIS 6.0 / Classic mode ASP.NET configuration -->   
<validation validateIntegratedModeConfiguration="false" />
</system.webServer>

 

 

参考资料:

1.http://www.west-wind.com/weblog/posts/168221.aspx

2.http://www.cnblogs.com/fanweixiao/archive/2008/04/16/1155650.html

3.http://mvolo.com/blogs/serverside/archive/2008/04/15/Creating-portable-ASP.NET-applications-that-work-on-IIS-6.0_2C00_-IIS-7.0-Classic_2C00_-and-IIS-7.0-Integrated-modes.aspx

4.http://www.cnblogs.com/blodfox777/archive/2009/11/23/1608935.html

5.http://www.cnblogs.com/gaoweipeng/archive/2009/05/17/1458762.html(Web.config配置文件详解(新手必看))

=============================

下面是iis7 模块化安装实现UrlRewrite:

1.http://blog.sina.com.cn/s/blog_559b695f0100fn2l.html

2.http://www.improve.dk/blog/2006/12/11/making-url-rewriting-on-iis7-work-like-iis6

 

本文来源:http://www.cnblogs.com/TTTT/archive/2009/12/17/1626419.html


如果给你带来帮助,欢迎微信或支付宝扫一扫,赞一下。