我有两个ASP。NET Web项目(ProjectA和projecb)。当ProjectA中的类正在实例化ProjectB中的一个类时,它使用了一个资源文件Blah。resx,我得到这个错误:

一个System.Resources类型的异常。mscorlib.dll中出现了MissingManifestResourceException',但在用户代码中没有处理。 无法找到适用于指定区域性或中性区域性的任何资源。确保“资源。等等。”资源“正确嵌入或链接到程序集”App_GlobalResources。Sn_flri6”,或者所有所需的附属程序集都是可加载的并具有全符号。

是什么导致的?

在微软的网站上有一篇关于http://support.microsoft.com/kb/318603的文章,它建议:

要解决此问题,请移动所有其他类定义,使它们出现在表单的类定义之后。

这是一个Windows窗体项目的解决方案,我不确定这是否也适用于Web项目。


当前回答

在我的例子中,这个问题是由错误的类定义顺序引起的。例如,我在Form类之前添加了另一个类定义:

namespace MyBuggyWorld
{
    public class BackendObject //This hack broke the VS 2017 winform designer and resources linker!
    {
        public TcpClient ActiveClient { get; set; }
        public BackgroundWorker ActiveWorker { get; set; }
    }

    public partial class FormMain : Form
    {
    }
}

在移动BackendObject到文件的末尾(更好的是将其移动到一个单独的文件),做项目清洁+重建解决了这个问题。

其他回答

我只是在WPF项目中碰到了同样的异常。问题发生在我们最近移动到另一个名称空间(ProblemAssembly)的程序集中。支持ProblemAssembly.Controls)。试图从程序集中存在的第二个资源文件访问资源时发生异常。

事实证明,附加的资源文件没有正确地将引用从旧的名称空间名称移动到新的名称空间名称。

在资源文件的designer.cs中,有一个静态属性用于获取ResourceManager。在该getter中,字符串仍然引用旧的名称空间。一旦将其纠正为新的名称空间,问题就解决了:

global::System.Resources.ResourceManager temp = 
     new global::System.Resources.ResourceManager(
          "ProblemAssembly.Support.Properties.Stuff", typeof(Stuff).Assembly);

本来应该是:

global::System.Resources.ResourceManager temp = 
     new global::System.Resources.ResourceManager(
          "ProblemAssembly.Controls.Properties.Stuff", typeof(Stuff).Assembly);

一种方法是将共享的类/资源放在单独的类库项目中,并在两个网站中引用它们。

Dotfuscation也会引发此错误,因为resx设计器文件依赖于反射。如果你使用Dotfuscator,它会破坏你的resx文件。您必须始终将它们添加到混淆过程中。

在将Windows Forms csproj迁移到新的sdk风格的项目格式时,也会遇到这种异常。如果子文件夹中有任何窗体或用户控件,则*.;resx文件将使用包含子文件夹的名称空间生成,该名称空间可能与*. designer .cs名称空间不匹配。解决方案是在csproj中添加如下内容:

<EmbeddedResourceUseDependentUponConvention>true</EmbeddedResourceUseDependentUponConvention>

我在尝试在EF上运行update-database命令时遇到了同样的问题。结果发现,抛出异常的迁移将.resx文件排除在项目之外。我只是右键单击。resx文件,然后单击“Include In Project”。 问题解决了。