所以我需要在同一解决方案中使用同一dll的两个不同版本,我通过使用外部别名设法做到这一点(任何人试图使用同一dll的两个不同版本应该尝试此解决方案)。问题是,现在我得到这个fileloadeexception HRESULT: 0x80131040一旦我的应用程序开始运行。有人知道这个问题的可能原因和/或解决方案吗?
是的,我必须更改其中一个dll的名称,不,目前仅使用后一个版本是不可能的。
我设法使用两个不同版本的同一dll使用appDomain。它非常干净,总是可以工作,但是,它涉及到反射和appDomain创建,这是性能关键应用程序的开销。这是如何在控制台应用程序中完成的,你可以在asp.net中做同样的事情:
//Console app
using System;
using System.IO;
using System.Reflection;
namespace ConsoleApp1
{
class Program
{
static System.AppDomain oldAssemblyDomain = null;
static System.AppDomain newAssemblyDomain = null;
static void Main(string[] args)
{
LoadOldVersion();
LoadNewVersion();
Console.ReadLine();
}
private static void LoadOldVersion()
{
oldAssemblyDomain = System.AppDomain.CreateDomain("oldAssemblyDomain", null);
oldAssemblyDomain.DoCallBack(()=>{
string dllName = "ClassLibrary1.dll";
Assembly assembly = Assembly.LoadFile(Directory.GetCurrentDirectory() + @"" + dllName);
Type type = assembly.GetType("ClassLibrary1.Class1");
MethodInfo minfo = type.GetMethod("SayHello", BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Static | BindingFlags.Instance);
var returnValue=minfo.Invoke(Activator.CreateInstance(type), null);
Console.WriteLine(returnValue.ToString());
});
}
private static void LoadNewVersion()
{
newAssemblyDomain = System.AppDomain.CreateDomain("newAssemblyDomain", null);
newAssemblyDomain.DoCallBack(() =>
{
string dllName = "ClassLibrary2.dll";
Assembly assembly = Assembly.LoadFile(Directory.GetCurrentDirectory() + @"" + dllName);
Type type = assembly.GetType("ClassLibrary1.Class1");
MethodInfo minfo = type.GetMethod("SayHello", BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Static | BindingFlags.Instance);
var returnValue = minfo.Invoke(Activator.CreateInstance(type), null);
Console.WriteLine(returnValue.ToString());
});
}
}
}
//Lib
namespace ClassLibrary1
{
public class Class1
{
public static string SayHello()
{
return "Hello 1";
}
}
}