我很想知道如何使用带有 FormatterAssemblyStyle.Full 的二进制格式化程序的汇编格式来“打破”反序列化。
文档说明了这一点:
在完整模式下,反序列化期间使用的程序集必须与序列化期间使用的程序集完全匹配。
我想如果我用程序集的 1.0.0.0 版本序列化一个对象(_person,它是一个具有值类型字段的简单类),然后尝试用程序集的 v1.2.0.0(更新 AssemblyInfo.cs)反序列化,我会得到一个反序列化异常。但是,它成功反序列化。
我错过了什么吗?
我正在使用以下内容序列化到文件:
BinaryFormatter formatter = new BinaryFormatter();
formatter.AssemblyFormat = System.Runtime.Serialization.Formatters.FormatterAssemblyStyle.Full;
using (Stream stream = new FileStream(fileName,
FileMode.Create,
FileAccess.Write,
FileShare.None))
{
formatter.Serialize(stream, _person);
stream.Close();
}
然后使用以下反序列化:
BinaryFormatter formatter = new BinaryFormatter();
formatter.AssemblyFormat = System.Runtime.Serialization.Formatters.FormatterAssemblyStyle.Full;
using (Stream stream = new FileStream(fileName, FileMode.Open, FileAccess.Read, FileShare.Read))
{
_person = (Person)formatter.Deserialize(stream);
stream.Close();
}
我还注意到使用 FormatterAssemblyStyle.Full 和 FormatterAssemblyStyle.Simple 生成的序列化文件都包含完整的版本信息(例如版本 1.0.0.0 Culture = 中性,PublicKeyToken = null) - 我认为 Simple 不会添加所有这些信息?(请参阅此处的格式化程序和程序集名称部分)
更新1:
到目前为止,我看到的唯一区别是,如果我使用 Simple,那么我不必将OptionalField
属性放置到序列化类中的新字段中,就可以成功地反序列化旧版本。如果我使用 Full,那么它会抛出异常,除非我将OptionalField
属性放在新字段上。如果使用非强命名的程序集,这是唯一的区别吗?
有关详细信息,请参阅此。
提前致谢