如何将 byte[] 反序列化为要在方法调用时转换的通用对象
How to deserialize byte[] into generic object to be cast at method call
我正在研究对象加密class。我已经解决了所有问题,但我希望能够使用一种反序列化方法 encrypt/decrypt 任何对象类型。到目前为止,唯一阻碍我的是反序列化方法。我有 returning type(object) 函数,希望 returning 弱类型对象。只要我在 return 赋值期间转换类型,它就可以工作,但如果我反序列化为类型 'object',结果是 byte[]。
这意味着我必须为我要操作的每个对象(T) 编写一个反序列化方法。我想要做的是将 Type(T) 作为参数传递给反序列化方法,这样我就可以反序列化为 object(T),然后 return 类型化对象。
问题是显然不允许使用类型化参数。
如果我这样做 obj = (type.GetType())br.Deserialize(ms);
我在“(object(T)) 和 br.”之间得到 ; expected
。
如果我这样做 obj = (br.Deserialize(ms) as type);
我得到 The type of namespace "type" could not be found. (are you missing a using directive or an assembly reference?)
或者我收到符号无法解析的错误。
任何帮助表示赞赏。完整代码如下。
private byte[] serialize(object param)
{
byte[] encMsg = null;
using (MemoryStream ms = new MemoryStream())
{
IFormatter br = new BinaryFormatter();
br.Serialize(ms, param);
encMsg = ms.ToArray();
}
return encMsg;
}
private object deserialize(byte[] param)
{
object obj = null;
using (MemoryStream ms = new MemoryStream(param))
{
IFormatter br = new BinaryFormatter();
obj = (br.Deserialize(ms) as myObject);
}
return obj;
}
private byte[] encrypt(byte[] param)
{
byte[] encMsg = null;
using (Aes myAes = Aes.Create())
{
myAes.Padding = PaddingMode.ANSIX923;
ICryptoTransform autoBot = myAes.CreateEncryptor(myAes.Key, myAes.IV);
using (MemoryStream ms = new MemoryStream())
{
using (CryptoStream cs = new CryptoStream(ms, autoBot, CryptoStreamMode.Write))
{
cs.Write(param, 0, (int)param.Length);
}
encMsg = ms.ToArray();
}
}
return encMsg;
}
private byte[] decrypt(byte[] key, byte[] iv, byte[] param)
{
byte[] dcparam = null;
using (Aes myAes = Aes.Create())
{
myAes.Padding = PaddingMode.ANSIX923;
ICryptoTransform autoBot = myAes.CreateDecryptor(key, iv);
using (MemoryStream ms = new MemoryStream())
{
using (CryptoStream cs = new CryptoStream(ms, autoBot, CryptoStreamMode.Write))
{
cs.Write(param, 0, (int)param.Length);
}
dcparam = ms.ToArray();
}
}
return dcparam;
}
你要反序列化的类型必须在编译时知道。所以你的方法可以是这样的:
private T Deserialize<T>(byte[] param)
{
using (MemoryStream ms = new MemoryStream(param))
{
IFormatter br = new BinaryFormatter();
return (T)br.Deserialize(ms);
}
}
现在你可以像
一样使用它了
var myclass = Deserialize<MyClass>(buf);
您只需使用 class 的类型参数即可。
通过尝试动态执行 GetType 或强制转换,您将强制执行运行时评估,而不是使用泛型创建编译时引用版本。
类型参数将编译您的 class 的单独版本,该版本对于编译器遇到的每个参数类型 T 都是强类型的。所以T其实是强引用的占位符
obj = (br.Deserialize(ms) as T);
我正在研究对象加密class。我已经解决了所有问题,但我希望能够使用一种反序列化方法 encrypt/decrypt 任何对象类型。到目前为止,唯一阻碍我的是反序列化方法。我有 returning type(object) 函数,希望 returning 弱类型对象。只要我在 return 赋值期间转换类型,它就可以工作,但如果我反序列化为类型 'object',结果是 byte[]。
这意味着我必须为我要操作的每个对象(T) 编写一个反序列化方法。我想要做的是将 Type(T) 作为参数传递给反序列化方法,这样我就可以反序列化为 object(T),然后 return 类型化对象。
问题是显然不允许使用类型化参数。
如果我这样做 obj = (type.GetType())br.Deserialize(ms);
我在“(object(T)) 和 br.”之间得到 ; expected
。
如果我这样做 obj = (br.Deserialize(ms) as type);
我得到 The type of namespace "type" could not be found. (are you missing a using directive or an assembly reference?)
或者我收到符号无法解析的错误。 任何帮助表示赞赏。完整代码如下。
private byte[] serialize(object param)
{
byte[] encMsg = null;
using (MemoryStream ms = new MemoryStream())
{
IFormatter br = new BinaryFormatter();
br.Serialize(ms, param);
encMsg = ms.ToArray();
}
return encMsg;
}
private object deserialize(byte[] param)
{
object obj = null;
using (MemoryStream ms = new MemoryStream(param))
{
IFormatter br = new BinaryFormatter();
obj = (br.Deserialize(ms) as myObject);
}
return obj;
}
private byte[] encrypt(byte[] param)
{
byte[] encMsg = null;
using (Aes myAes = Aes.Create())
{
myAes.Padding = PaddingMode.ANSIX923;
ICryptoTransform autoBot = myAes.CreateEncryptor(myAes.Key, myAes.IV);
using (MemoryStream ms = new MemoryStream())
{
using (CryptoStream cs = new CryptoStream(ms, autoBot, CryptoStreamMode.Write))
{
cs.Write(param, 0, (int)param.Length);
}
encMsg = ms.ToArray();
}
}
return encMsg;
}
private byte[] decrypt(byte[] key, byte[] iv, byte[] param)
{
byte[] dcparam = null;
using (Aes myAes = Aes.Create())
{
myAes.Padding = PaddingMode.ANSIX923;
ICryptoTransform autoBot = myAes.CreateDecryptor(key, iv);
using (MemoryStream ms = new MemoryStream())
{
using (CryptoStream cs = new CryptoStream(ms, autoBot, CryptoStreamMode.Write))
{
cs.Write(param, 0, (int)param.Length);
}
dcparam = ms.ToArray();
}
}
return dcparam;
}
你要反序列化的类型必须在编译时知道。所以你的方法可以是这样的:
private T Deserialize<T>(byte[] param)
{
using (MemoryStream ms = new MemoryStream(param))
{
IFormatter br = new BinaryFormatter();
return (T)br.Deserialize(ms);
}
}
现在你可以像
一样使用它了var myclass = Deserialize<MyClass>(buf);
您只需使用 class 的类型参数即可。
通过尝试动态执行 GetType 或强制转换,您将强制执行运行时评估,而不是使用泛型创建编译时引用版本。
类型参数将编译您的 class 的单独版本,该版本对于编译器遇到的每个参数类型 T 都是强类型的。所以T其实是强引用的占位符
obj = (br.Deserialize(ms) as T);