如何将 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);