.NET Framework 到 .NET Core 迁移序列化问题
.NET Framework to .NET Core migration serialization issue
我已经将许多 class 库从 .NET Framework 4.5 移植到 .NET Standard 2.0。从 .NET Framework 4.8 控制台应用程序使用这些库工作正常。但是,从 .NET Core 2.2 控制台应用程序引用库会导致以下异常:
SerializationException: Type 'System.Collections.Hashtable+SyncHashtable' in Assembly 'System.Runtime.Extensions, Version=4.2.1.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' is not marked as serializable
有堆栈跟踪
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.CheckSerializable(Type t)
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.ParseObject(ParseRecord pr)
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.Parse(ParseRecord pr)
at System.Runtime.Serialization.Formatters.Binary.BinaryParser.ReadObjectWithMapTyped(BinaryHeaderEnum binaryHeaderEnum)
at System.Runtime.Serialization.Formatters.Binary.BinaryParser.Run()
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.Deserialize(BinaryParser serParser, Boolean fCheck)
at System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream, Boolean check)
at System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream)
我内心对失败的框架最调用的代码是这样的:
public static object Deserialize(BinaryReader binaryReader)
{
BinaryReader binaryReader = new BinaryReader(inStream);
BinaryFormatter binaryFormatter = new BinaryFormatter();
return binaryFormatter.Deserialize(binaryReader.BaseStream);
}
有什么想法吗?
Microsoft 的回答:“在 .NET Core 中,与在 .NET Framework 中相比,可二进制序列化的类型更少。这是设计使然,因为基于 BinaryFormatter 的序列化在历史上一直很脆弱并且容易出现安全问题。 SyncHashtable 当前不可序列化。但是我们可能应该这样做。同时你需要避免序列化它。这可能意味着使用 Hashtable 并手动锁定而不是使用 SyncHashtable。或者可能(高级)使用 BinaryFormatter 的扩展机制来解决这个问题。”
此处 GitHub 上的对话:https://github.com/dotnet/corefx/issues/37708#issuecomment-493641762
我已经将许多 class 库从 .NET Framework 4.5 移植到 .NET Standard 2.0。从 .NET Framework 4.8 控制台应用程序使用这些库工作正常。但是,从 .NET Core 2.2 控制台应用程序引用库会导致以下异常:
SerializationException: Type 'System.Collections.Hashtable+SyncHashtable' in Assembly 'System.Runtime.Extensions, Version=4.2.1.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' is not marked as serializable
有堆栈跟踪
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.CheckSerializable(Type t)
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.ParseObject(ParseRecord pr)
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.Parse(ParseRecord pr)
at System.Runtime.Serialization.Formatters.Binary.BinaryParser.ReadObjectWithMapTyped(BinaryHeaderEnum binaryHeaderEnum)
at System.Runtime.Serialization.Formatters.Binary.BinaryParser.Run()
at System.Runtime.Serialization.Formatters.Binary.ObjectReader.Deserialize(BinaryParser serParser, Boolean fCheck)
at System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream, Boolean check)
at System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream)
我内心对失败的框架最调用的代码是这样的:
public static object Deserialize(BinaryReader binaryReader)
{
BinaryReader binaryReader = new BinaryReader(inStream);
BinaryFormatter binaryFormatter = new BinaryFormatter();
return binaryFormatter.Deserialize(binaryReader.BaseStream);
}
有什么想法吗?
Microsoft 的回答:“在 .NET Core 中,与在 .NET Framework 中相比,可二进制序列化的类型更少。这是设计使然,因为基于 BinaryFormatter 的序列化在历史上一直很脆弱并且容易出现安全问题。 SyncHashtable 当前不可序列化。但是我们可能应该这样做。同时你需要避免序列化它。这可能意味着使用 Hashtable 并手动锁定而不是使用 SyncHashtable。或者可能(高级)使用 BinaryFormatter 的扩展机制来解决这个问题。”
此处 GitHub 上的对话:https://github.com/dotnet/corefx/issues/37708#issuecomment-493641762