我们遇到了看似常见的错误
Could not load type 'System.Runtime.CompilerServices.ExtensionAttribute' from assembly 'mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
在需要针对 .Net 4.0 编译但构建在运行 Windows Server 2012(使用 .Net 4.5)的构建服务器上的项目中。该项目是一个 Web 应用程序,它被部署到运行 2003 的 Web 服务器上,其中不能选择安装 .Net 4.5。它与“经典”.Net 4.0 相悖
从类似的问题中,我们正在尝试 MSBuild 的命令行选项:
/property:FrameworkPathOverride="C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0"
我们还尝试了各种组合
/property:ReferencePath="C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0"
/property:NoStdLib=true
/property:NoCompilerStandardLib=true
参考程序集(包括 .dll 文件)实际上安装在构建服务器上的那个位置。但是当我们部署网站并访问主页时,我们得到了那个错误。(有趣的是,在页面重新加载时,错误消失了,并且站点正常运行。)针对 .Net 4.0 程序集进行编译所需的 MSBuild 参数是什么?
更新 我在 MSBuild 上打开了可笑级别的日志记录,我看到它显然是针对 .Net 4.0 参考程序集构建的:
Resolved file path is "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0\mscorlib.dll
而且我没有看到任何提及该文件夹或构建服务器工作目录之外的程序集。所以它看起来可以正确编译,但是当部署在 Web 服务器上时,它会抛出异常。
至于页面重新加载时异常消失,我想知道这是否与标记预编译步骤有关。我们在构建服务器上运行 aspnet_compile。也许如果生成的程序集出现异常,Web 服务器将重新编译它。重新编译的程序集很好,因为它是用真正的 .Net 4.0 创建的。