这是我的代码,我在反序列化时遇到此错误。我在同一个电话中对它进行测试,因此.net的版本控制不应成为问题。我的用户数据是一个基本的poco对象。
步骤1,序列化和加密:
byte[] userDataArray;
BinaryFormatter bf = new BinaryFormatter();
using (MemoryStream ms = new MemoryStream())
{
bf.Serialize(ms, _logicLibrary.userData);
userDataArray = ms.ToArray();
}
string data = Encoding.UTF8.GetString(userDataArray);
var encrytedUserData = logic.Encrypt(data);
return Encoding.UTF8.GetBytes(encrytedUserData);
第2步解密和反序列化:
public UserData DeserializeUserData(string data) { string decryptedSerializedData = _logicLibrary.RunDecrypt(data); var dataBytes = Encoding.UTF8.GetBytes(decryptedSerializedData); BinaryFormatter bf = new BinaryFormatter(); using (MemoryStream ms = new MemoryStream(dataBytes)) { return bf.Deserialize(ms) as UserData; } }
反序列化时出现错误:
{" Binary stream' 189'不包含有效的BinaryHeader。可能 原因是无效的流或对象版本之间的变化 序列化和反序列化。"}
答案 0 :(得分:1)
您可以执行类似
的操作Convert.ToBase64String(arrayOfData);
Convert.FromBase64String(stringBase64Encoded);
获取字符串并将其转换回字节数组。
https://msdn.microsoft.com/en-us/library/dhx0d524(v=vs.110).aspx
https://msdn.microsoft.com/en-us/library/system.convert.frombase64string(v=vs.110).aspx
答案 1 :(得分:0)
基于这里的好建议,我重新设计了加密方法,以接受byte []类型的输入和输出。之后,我确保任何不是字符串的数据都不会触及基于很多东西的Encoding.UTF8,包括以下post。这些提示相结合,使我的代码工作。 UserData是一个自定义类。
private UserData DeserializeUserData(byte[] data)
{
byte[] decryptedSerializedData = logic.Decrypt(data);
BinaryFormatter bf = new BinaryFormatter();
using (MemoryStream ms = new MemoryStream(decryptedSerializedData))
{
return bf.Deserialize(ms) as UserData;
}
}
private byte[] SerializeUserData(UserData userData)
{
byte[] userDataArray;
BinaryFormatter bf = new BinaryFormatter();
using (MemoryStream ms = new MemoryStream())
{
bf.Serialize(ms, userData);
userDataArray = ms.ToArray();
}
return logic.Encrypt(userDataArray);
}