c# - 如何将 byte[] 反序列化为要在方法调用时转换的通用对象

标签 c# object serialization dynamic aes

我正在研究一个对象加密类。我已经解决了所有问题,但我希望能够使用一种反序列化方法加密/解密任何对象类型。到目前为止,唯一阻碍我的是反序列化方法。我有返回类型(对象)的函数,希望返回弱类型对象。只要我在返回值赋值期间转换类型,它就可以工作,但如果我反序列化为类型“object”,结果是 byte[]。

这意味着我必须为我要操作的每个对象 (T) 编写一个反序列化方法。我想要做的是将 Type(T) 作为参数传递给反序列化方法,以便我可以反序列化为 object(T),然后返回类型化对象。

问题是使用类型参数显然是不允许的。
如果我做 obj = (type.GetType())br.Deserialize(ms); 我得到 ;预期在“(object(T)) 和 br.”之间。

如果我执行 obj = (br.Deserialize(ms) as type); 我得到 The type of namespace "type"could not be found。 (您是否缺少 using 指令或程序集引用?)

或者我收到符号无法解析的错误。 任何帮助表示赞赏。完整代码如下。

        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);

关于c# - 如何将 byte[] 反序列化为要在方法调用时转换的通用对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33616621/

相关文章:

java - conwert 对象,其中包含 utf-8 的字符串到具有正确编码的字符串

javascript - JavaScript 上的火星到漫游者。我需要能够向流动站发出一系列命令并按顺序执行它们。

c# - 如何通过 MSMQ(使用 WCF)发送 XDocument?

c# - 澄清在 MVVM 中绑定(bind) Listbox.SelectedItem

C# .NET - 删除的路径是目录还是文件

javascript - hasOwnProperty - 即使拥有该属性也不会显示属性

java - 我们可以为序列化对象分配名称吗?

serialization - GWT 中的 IsSerializable 或 NotSerializable 是什么?

c# - 等效于 WPF .NET 5、.NET 6 或 .Net Core 中的 UserSettings/ApplicationSettings

c# - 基类和派生类中的静态字段