【问题标题】:Error CS0433 in large precompiled Asp.net Website Project大型预编译 Asp.net 网站项目中的错误 CS0433
【发布时间】:2013-02-09 02:38:00
【问题描述】:

背景

我接手了一个非常大的 asp.net 网站项目。旧的部署过程是将 .cs、.aspx 和 .ascx 文件复制到 IIS 并使其即时构建。我想预编译它并使用 TeamCity 自动部署它。我已经用其他一些网站项目做到了这一点。

该项目有大约 350 个用户控件,这些控件很好地组织在文件夹中,但可以在任何地方使用。从其他文件夹引用的控件,相互引用...基本上是循环文件引用的噩梦。

我的尝试

我的第一次尝试是像其他人一样构建它。 MSbuild 整个 vs2012 解决方案。我遇到了大量的“不允许循环文件引用”。来发现所有这些井井有条的控件到处都在使用,并且到处都有循环引用。 I read this 我将“web.config”切换为compilation batch="false",然后在构建中将站点设置为“不可更新”和“使用固定命名程序集”。该站点已构建,但在我的四核、ssd、16gb ram 开发盒上编译需要 25 分钟。这是不可接受的构建时间。

我知道,如果我关闭“使用固定命名程序集”,网站的构建速度会显着加快。 (我已经在一个较小的网站上证明了这一点。它从 4 分钟缩短到了 45 秒)。当我删除该设置时,我会遇到奇怪的构建错误:

c:\Projects\Web\Site.master(146): error CS0433: The type 'ASP.usercontrols_modules_viewprofilepopup_ascx' exists in both 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_viewprofilepopup.ascx.4101713c.dll' and 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_xa514so5.dll'

c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_site.master.cdcab7d2.0.cs(927): error CS0433: The type 'ASP.usercontrols_modules_viewprofilepopup_ascx' exists in both 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_viewprofilepopup.ascx.4101713c.dll' and 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_xa514so5.dll'

error ASPPARSE: c:\Projects\web\Web\UserControls\Modules\JobsLeftMenu.ascx(128): error CS0433: The type 'ASP.usercontrols_modules_imagesgallerymodule_ascx' exists in both 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_imagesgallerymodule.ascx.4101713c.dll' and 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_nvrj33tx.dll'

error ASPPARSE: c:\Projects\web\Web\Site.master(146): error CS0433: The type 'ASP.usercontrols_modules_viewprofilepopup_ascx' exists in both 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_viewprofilepopup.ascx.4101713c.dll' and 'c:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\web\8d37b2c6\4c39f0a\App_Web_xa514so5.dll'

这里是确切的 aspnet_compiler.exe 命令:

aspnet_compiler.exe -v /web -p Web\ -f "预编译的网络"

我四处搜寻答案。不,它们不会在任何地方的代码中重复。它们恰好位于不同的文件夹中,由不同文件夹中的其他控件使用。我有一种感觉,这是由于循环文件引用的事情。好的。我删除了其中一些的使用,以查看它是否会构建,并且构建过程只是转移到其他错误,就像这个错误一样。我不能完全删除代码以适应这种情况...如何在不打开“使用固定命名程序集”的情况下修复这些错误?

我尝试过的方法

  1. 清除了整个系统中的Temporary ASP.NET Files
  2. 尝试直接在 Visual Studio 2012 中“发布”。同样的错误。
  3. 尝试将站点转换为 Web 应用程序,但出现太多错误(超过 600 个以上)。
  4. 再次:确保没有重复的文件和代码可以解释它。我使用 notepad++ 对整个解决方案文件夹进行了文本搜索,以验证没有其他同名控件。
  5. Checked this.
  6. 我开启了 msbuild 性能调整:/m /p:CreateHardLinksForCopyLocalIfPossible=true /p:BuildInParallel=true

我很困惑,似乎认为我唯一的选择是重写应用程序,在我转换为 Web 应用程序时解决错误,或者继续将源代码部署到网络服务器但自动执行。

【问题讨论】:

  • 上面列出的错误输出是运行 aspnet_compiler 得到的吗?我本来希望看到循环引用错误。
  • @DavidEbbo 该错误是由使用 web.config 运行引起的:编译批处理 =“false”和没有“固定名称”的 msbuild。
  • 那么在什么情况下您会看到Circular file references are not allowed 错误?当测试一个琐碎的循环场景时,这就是我得到的。

标签: asp.net .net-4.0 msbuild visual-studio-2012


【解决方案1】:

我知道您已经尝试过,但避免循环引用将是您最好的选择。请注意,“循环引用”一词实际上并不完全正确。构建系统抱怨的是目录级别的循环引用,而不是文件级别。

例如sub1\page.aspx 使用 sub2\uc1.ascx 使用 sub1\uc2.ascx

在文件级别,没有圆圈,但在目录级别有,这与批处理的工作方式相混淆。

虽然您似乎遇到了太多这样的情况,以至于无法解决,但我敢打赌,如果您查看“目录圈”的详细信息,那肯定不是那么多。绘制参考图可能有助于理解事物。

然后您只需将违规者移动到不同的文件夹并相应地更改链接。

是的,这是一个痛苦的过程,但很可能可以解决。

【讨论】:

  • 将所有控件移动到一个文件夹中也能解决问题吗?另外,这会修复“'blah'类型中存在'blah'”错误吗?
  • 是的,将所有控件移动到一个文件夹中可以解决此问题,尽管这可能需要调整大量引用。它还将修复“类型存在于 2 个地方”错误。请注意,您可能同时拥有解析时间引用(@register 指令)和运行时引用(例如 LoadControl())。您只需要修复第一部分即可编译,但您需要实际运行其余部分。
猜你喜欢
  • 2010-10-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-12-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-09
相关资源
最近更新 更多