前阵子装了VS2010,由于之前的项目都是基于VS2008开发的,因此,打开之前版本的解决方案,就会弹出项目转换向导,将解决方案升级到VS2010版本的,但是最近总是转换后,再编译项目就会报错,报错内容:“在应用程序级别之外使用注册为 allowDefinition='MachineToApplication' 的节是错误的。如果在 IIS 中没有将虚拟目录配置为应用程序,则可能导致此错误。”
网上查了一下,都说是根目录下有多个web.config文件,搜索了一下,果然多出了个web.config文件。但是我之前还好好地,怎么转换后就多了一个呢,原来在转换时,如果直接选择“完成”按钮,或者“下一步”时候选择了“是,在转换前进行备份”,而备份的默认位置就是在项目根目录下建立一个“Backup”文件夹,将项目备份了进去,而此时自然就在这个文件夹中又多了个web.config。这就导致了上面的报错提示。
解决的方法很简单,以后备份时候不要备份到根目录下即可。不过话说回来了,都是默认的选项,最后竟然弄个错误出来,这确实是设计软件时不应该的。
这个报错信息,一般是因为web应用程序项目下面有多个独立的web.config文件存在。除了上述这种导致,也有一些其他原因可能导致此问题。比如在同一个解决方案中,添加了多个ASP.net网站,或者web应用程序项目。因为每个网站或web应用程序都默认存在一个web.config文件,所以F5调试的时候,也会出现这种错误。从网上查到,有三种解决方法:
1.最方便的,修改附属(非启动项目)Asp.net网站或web应用程序的web.config文件,比如我的解决方案中有两个asp.net网站 web1和web2。web1作为启动项目。那么就要修改web2的 web.config文件。打开web2的web.config文件,删除<configSections>节和<authentication mode="Windows" />节。注意,是删除,不是注释,注释是不起作用的。然后就可以用F5调试了。这时候web2就作为web1的附属项目。
2. 高手用的,因为删除那两个节的后果,目前还不清楚。但肯定是有负作用的。那就尽量不要删除,错误提示说需要把非启动项目在IIS中配置成虚拟目录,就照办好了。修改启动项目的属性,“启动选项,把使用默认web服务器,改成本地IIS,路径填http://localhost”,非启动项目就改成http://localhost/xxx/。如果项目全是Asp.net网站,那直接F5不管错误提示也可以,如果项目有web应用程序,这个时候F5是不行的。只好放弃调试。反正错误提示已经不影响正常编写代码和最终发布项目。
3. 根本解决办法,重新考虑项目的架构,我当初遇到这个问题是因为需要每个非启动项目都可以独立运行,方便将来配置二级域名,其实实现这种目的有很多种方法,比如建多个解决方案,发布的时候发布到一个目录里。主要是在项目架构上多作思考,尽量避免同一个解决方案下存在多个asp.net网站或web应用程序的问题。