В других случаях было предложено просто добавить SerializationBinder, который удаляет версию из типа сборки. Однако при использовании универсальных коллекций типа, обнаруженного в подписанной сборке, этот тип строго версионируется на основе своей сборки.
Вот что я нашел работы.
internal class WeaklyNamedAppDomainAssemblyBinder : SerializationBinder
{
public override Type BindToType(string assemblyName, string typeName)
{
ResolveEventHandler handler = new ResolveEventHandler(CurrentDomain_AssemblyResolve);
AppDomain.CurrentDomain.AssemblyResolve += handler;
Type returnedType;
try
{
AssemblyName asmName = new AssemblyName(assemblyName);
var assembly = Assembly.Load(asmName);
returnedType = assembly.GetType(typeName);
}
catch
{
returnedType = null;
}
finally
{
AppDomain.CurrentDomain.AssemblyResolve -= handler;
}
return returnedType;
}
Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
{
string truncatedAssemblyName = args.Name.Split(',')[0];
Assembly assembly = Assembly.Load(truncatedAssemblyName);
return assembly;
}
}
Однако, изменение глобального процесса связывания кажется мне довольно опасным. Странные вещи могут произойти, если сериализация происходит в нескольких потоках. Возможно, лучшее решение - это выполнить некоторые регулярные выражения для typeName?
Редактировать: Метод на основе строк не работает. Дженерики, очевидно, нуждаются в полном строго названном типе. Довольно отвратительно, если вы спросите меня.