c# - 将对象序列化并存储在另一个实现 IXmlSerializable 的对象中

标签 c# xml-serialization ixmlserializable

我想对我的对象 Exception 的实例进行 XML 序列化,并将其存储在另一个对象 ExceptionReportXMLNode[] Nodes 属性中。

[System.Diagnostics.DebuggerStepThroughAttribute()]
[System.CodeDom.Compiler.GeneratedCodeAttribute("System.Runtime.Serialization", "4.0.0.0")]
[System.Xml.Serialization.XmlSchemaProviderAttribute("ExportSchema")]
[System.Xml.Serialization.XmlRootAttribute(IsNullable = false)]
public partial class ExceptionReport : object, System.Xml.Serialization.IXmlSerializable
{
    public System.Xml.XmlNode[] Nodes { get; set; }

    public void ReadXml(System.Xml.XmlReader reader)
    {
        this.Nodes = System.Runtime.Serialization.XmlSerializableServices.ReadNodes(reader);
    }

    public void WriteXml(System.Xml.XmlWriter writer)
    {
        System.Runtime.Serialization.XmlSerializableServices.WriteNodes(writer, this.Nodes);
    }
}
public class Exception
{
    public string ExceptionText;
    public string exceptionCode;
    public string locator;
}

我该怎么做才能得到这样的结果:

<ExceptionReport xmlns="http://www.opengis.net/ows" >
  <Exception exceptionCode="1">my first instance</Exception>
  <Exception exceptionCode="2">my second instance</Exception>
</ExceptionReport>

到目前为止,我有以下内容,但我需要知道如何序列化这些对象并将它们存储在 ExceptionReport 节点数组中。

ExceptionReport er = new ExceptionReport();

Exception exception_item1 = new Exception();
exception_item1.ExceptionText = "my first instance";
exception_item1.exceptionCode = "1";

Exception exception_item2 = new Exception();
exception_item2.ExceptionText = "my second instance";
exception_item2.exceptionCode = "2";

List<Exception> exceptions = new List<Exception>( exception_item1, exception_item2 );

最佳答案

[XmlRoot("ExceptionReport")]
    public partial class ExceptionReport
    {
        [XmlElement("Exception")]
        public List<Exception> Nodes { get; set; }

        public ExceptionReport()
        {
            Nodes = new List<Exception>();
        }
    }
    public class Exception
    {
        [XmlText]
        public string ExceptionText;
        [XmlAttribute("exceptionCode")]
        public int ExceptionCode;
        [XmlAttribute("locator")]
        public string Locator;
    }

然后为了序列化,我使用了以下扩展:

public static bool XmlSerialize<T>(this T item, string fileName)
        {
            return item.XmlSerialize(fileName, true);
        }
        public static bool XmlSerialize<T>(this T item, string fileName, bool removeNamespaces)
        {
            object locker = new object();

            XmlSerializerNamespaces xmlns = new XmlSerializerNamespaces();
            xmlns.Add(string.Empty, string.Empty);

            XmlSerializer xmlSerializer = new XmlSerializer(typeof(T));

            XmlWriterSettings settings = new XmlWriterSettings();
            settings.Indent = true;
            settings.OmitXmlDeclaration = true;

            lock (locker)
            {
                using (XmlWriter writer = XmlWriter.Create(fileName, settings))
                {
                    if (removeNamespaces)
                    {
                        xmlSerializer.Serialize(writer, item, xmlns);
                    }
                    else { xmlSerializer.Serialize(writer, item); }

                    writer.Close();
                }
            }

            return true;
        }
        public static T XmlDeserialize<T>(this string s)
        {
            object locker = new object();
            StringReader stringReader = new StringReader(s);
            XmlTextReader reader = new XmlTextReader(stringReader);
            try
            {
                XmlSerializer xmlSerializer = new XmlSerializer(typeof(T));
                lock (locker)
                {
                    T item = (T)xmlSerializer.Deserialize(reader);
                    reader.Close();
                    return item;
                }
            }
            finally
            {
                if (reader != null)
                { reader.Close(); }
            }
        }
        public static T XmlDeserialize<T>(this FileInfo fileInfo)
        {
            string xml = string.Empty;
            using (FileStream fs = new FileStream(fileInfo.FullName, FileMode.Open, FileAccess.Read))
            {
                using (StreamReader sr = new StreamReader(fs))
                {
                    return sr.ReadToEnd().XmlDeserialize<T>();
                }
            }
        }

像这样使用:

ExceptionReport report = new ExceptionReport();
            report.Nodes.Add(new Exception { ExceptionText = "my first instance", ExceptionCode = 1, Locator = "loc1" });
            report.Nodes.Add(new Exception { ExceptionText = "my second instance", ExceptionCode = 2 });
            report.XmlSerialize("C:\\test.xml");

我进行了测试,结果如您所愿。希望对您有所帮助...

PS - 扩展来 self 在代码项目上的库:http://www.codeproject.com/KB/dotnet/MBGExtensionsLibrary.aspx

关于c# - 将对象序列化并存储在另一个实现 IXmlSerializable 的对象中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7448364/

相关文章:

c# - XML(反)序列化无效字符串在 C# 中不一致?

c# - XML 序列化和 DefaultValue ("") c# 中的相关问题

c# - 使用 XmlSerializer 自定义序列化

IXmlSerializable 的 C# XML 序列化类型

c# - 更改冲突的程序集引用

c# - 如何在实体中的使用表中创建 PK 和唯一用户名(使用代码优先)?

java - java序列化问题

c# - 实现 IXmlSerializable 需要集合属性具有 Setter

c# - 转换 bool 值?在 View 中 bool

c# - 如何在多个子类上返回不同的类型?