如何解决将事件序列化为JSON
我正在使用Json进行序列化系统,但是我需要保存Buttons中的事件(onClick,onHover等)。有没有办法有效地做到这一点? (注意:这些事件都是动作)
解决方法
坦率地说,尝试序列化事件是糟糕的主意。
JSON通常用于序列化数据;事件不是数据-它们是实施细节。大多数JSON序列化程序(或更广泛地说:大多数 serializers )对委托/事件都不感兴趣,因为这与数据无关,因此:很可能发生任何事情您想要在此处执行的操作将需要手动进行。具体来说,这里的问题是 event (或更确切地说,底层的多播委托)实际上是零对,一对或多对“实例”(可选)和“方法”(必需)。 / p>
这里的方法是MethodInfo
,并且没有很好的方法将MethodInfo
序列化为文本(尽管至少在理论上是可行的,尽管这样做会易碎与代码更改。
实例是object
-大多数序列化器讨厌;在这种情况下,它将合并不确定类型的对象(参考)跟踪(可能不是有效载荷内的对象 )(因此:可能需要存储类型元数据)。
此外,反序列化对象模型以使您指向任意类型和方法是一个大量安全漏洞,并且是序列化程序中一个众所周知的RCE弱点,(不明智地,IMO)允许这样做之类的东西(例如BinaryFormatter
;有关此主题的更长时间的讨论,see here)。
关于相反的操作:只要实现不适合给定的序列化程序,最实用的选择就是停止与序列化程序进行斗争,并且使用它而不是反对它。例如,也许您可以创建一个看起来像域模型的域模型,但是它没有事件/代理,而可能只有string[]
/ {{1} }代表您需要应用的事件,而您的代码会担心如何在它们之间进行映射(将方法映射到字符串以及确定目标实例应该是什么,等等)。这样可以避免上述所有问题,并且还意味着您的数据现在独立于平台,有效负载和实现详细信息(您的表单布局)彼此独立。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。