.net core5.0下对象克隆_Clone_借用XmlSerializer序列化器_替换传统的BinaryFormatter器_解决XmlSerializer的缺陷
前言:传统的对象克隆在.net core5.0下已经不推荐了,微软给的解释是存在安全漏洞,其提供了几个替代类,其中就包括:XmlSerializer。
克隆方法经过了几次调整:
历史版本1-BinaryFormatter在.net 5.0下存在安全漏洞已不推荐使用且报异常;
历史版本2-微软推荐的替代类-XmlSerializer该方法依赖无参构造函数;
正在使用克隆版本: (T)JObject.FromObject(obj).ToObject(obj.GetType())
核心克隆代码:
/// <summary> /// 将一个实体对象的值复制到另一个对象 /// </summary> public static class ObjectExtensions { /// <summary> /// 对象克隆。 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="obj"></param> /// <returns></returns> public static T Clone<T>(this T obj) where T : class { T clone = default(T); #region 历史版本1-BinaryFormatter在.net 5.0下存在安全漏洞已不推荐使用且报异常 //BinaryFormatter在.net 5.0下存在安全漏洞已不推荐使用且报异常。 //参考链接:https://docs.microsoft.com/zh-cn/dotnet/standard/serialization/binaryformatter-security-guide //using (MemoryStream ms = new MemoryStream(1024)) //{ // BinaryFormatter binaryFormatter = new BinaryFormatter(null, new StreamingContext(StreamingContextStates.Clone)); // binaryFormatter.Serialize(ms, obj); // ms.Seek(0, SeekOrigin.Begin); // // 反序列化至另一个对象(即创建了一个原对象的深表副本) // clone = (T)binaryFormatter.Deserialize(ms); //} #endregion #region 历史版本2-XmlSerializer该方法依赖无参构造函数 ////该方法依赖无参构造函数 ////核心点2:这里的XmlSerializer序列化器要使用实例obj的类型,不能直接使用类型T,否则会报异常(当obj实例为T类型的子类时,可重现该异常) ////异常详细信息:"ClassName":"System.InvalidOperationException","Message":"There was an error generating the XML document.","Data":null,"InnerException":{"ClassName":"System.InvalidOperationException","Message":"The type MeShopPay.View.API.Models.ConfigModel.CallBackSettingPayPal was not expected. Use the XmlInclude or SoapInclude attribute to specify types that are not known statically." ////核心点3: T类型中不可包含接口类型属性,如:System.Collections.Generic.IEnumerable<T> ////异常详细信息:Cannot serialize member 'aaa.PingPong.RiskInfoModel.Goods' of type 'System.Collections.Generic.IEnumerable`1[[aaa.PingPong.GoodModel, aaa, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null]]', see inner exception for more details. //Type objType = obj.GetType(); //XmlSerializer tXmlSerializer = new XmlSerializer(objType); //using (MemoryStream ms = new MemoryStream(1024)) //{ // tXmlSerializer.Serialize(ms, obj); // ms.Seek(0, SeekOrigin.Begin); // // 反序列化至另一个对象(即创建了一个原对象的深表副本) // clone = (T)tXmlSerializer.Deserialize(ms); //} #endregion clone = (T)JObject.FromObject(obj).ToObject(obj.GetType()); return clone; } }
*感谢您的阅读。喜欢的、有用的就请大哥大嫂们高抬贵手“推荐一下”吧!你的精神 支持是博主强大的写作动力。欢迎转载!
*博主的文章是自己平时开发总结的经验,由于博主的水平不高,不足和错误之处在所难免,希望大家能够批评指出。
*我的博客: http://www.cnblogs.com/lxhbky/
*博主的文章是自己平时开发总结的经验,由于博主的水平不高,不足和错误之处在所难免,希望大家能够批评指出。
*我的博客: http://www.cnblogs.com/lxhbky/
浙公网安备 33010602011771号