2009-06-29 16 views
9

Mam zdefiniowane następujące klasy:Jak używać XmlSerializer wstawić ciąg xml

public class Root 
{ 
    public string Name; 
    public string XmlString; 
} 

i utworzonego obiektu:

Root t = new Root 
     { Name = "Test", 
      XmlString = "<Foo>bar</Foo>" 
     }; 

Kiedy użyć klasy XmlSerializer serializacji tego obiektu, powróci xml:

<Root> 
    <Name>Test</Name> 
    <XmlString>&lt;Foo&gt;bar&lt;/Foo&gt;</XmlString> 
</Root> 

Jak zrobić to nie kodować moje treści XmlString tak, że mogę dostać zserializowaną XML jako

<XmlString><Foo>bar</Foo></XmlString> 

Dzięki Ian

Odpowiedz

1

Byłbym bardzo zaskoczony, gdyby to było możliwe. Załóżmy, że możesz to zrobić - co by się stało, gdybyś miał zniekształcony kod XML w obiekcie - wszystko by się po prostu złamało.

Spodziewam się, że albo będziesz musiał napisać własną serializację dla tego przypadku, albo sprawisz, że pole XmlString będzie strukturą zawierającą pole foo.

2

Możesz (ab) użyć do tego celu IXmlSerializable interface i XmlWriter.WriteRaw. Ale jak wskazał Garethm, musisz napisać swój własny kod serializacji.

using System; 
using System.Xml; 
using System.Xml.Schema; 
using System.Xml.Serialization; 

namespace ConsoleApplicationCSharp 
{ 
    public class Root : IXmlSerializable 
    { 
    public string Name; 
    public string XmlString; 

    public Root() { } 

    public void WriteXml(System.Xml.XmlWriter writer) 
    { 
     writer.WriteElementString("Name", Name); 
     writer.WriteStartElement("XmlString"); 
     writer.WriteRaw(XmlString); 
     writer.WriteFullEndElement(); 
    } 

    public void ReadXml(System.Xml.XmlReader reader) { /* ... */ } 
    public XmlSchema GetSchema() { return (null); } 
    public static void Main(string[] args) 
    { 
     Root t = new Root 
     { 
     Name = "Test", 
     XmlString = "<Foo>bar</Foo>" 
     }; 
     System.Xml.Serialization.XmlSerializer x = new XmlSerializer(typeof(Root)); 
     x.Serialize(Console.Out, t); 
     return; 
    } 
    } 
} 

drukuje

<?xml version="1.0" encoding="ibm850"?> 
<Root> 
    <Name>Test</Name> 
    <XmlString><Foo>bar</Foo></XmlString> 
</Root> 
+0

Czy to także deserializuje? – configurator

+0

Jeśli zaimplementujesz metodę ReadXml (czytnik XmlReader), tak. – VolkerK

1

spróbuj tego:

public class Root 
{ 
    public string Name; 
    public XDocument XmlString; 
} 

Root t = new Root 
     { Name = "Test", 
      XmlString = XDocument.Parse("<Foo>bar</Foo>") 
     }; 
13

Można ograniczyć niestandardową serializacji po prostu element, który wymaga szczególnej uwagi jak tak.

public class Root 
{ 
    public string Name; 

    [XmlIgnore] 
    public string XmlString 
    { 
     get 
     { 
      if (SerializedXmlString == null) 
       return ""; 
      return SerializedXmlString.Value; 
     } 
     set 
     { 
      if (SerializedXmlString == null) 
       SerializedXmlString = new RawString(); 
      SerializedXmlString.Value = value; 
     } 
    } 

    [XmlElement("XmlString")] 
    [Browsable(false)] 
    [EditorBrowsable(EditorBrowsableState.Never)] 
    public RawString SerializedXmlString; 
} 

public class RawString : IXmlSerializable 
{ 
    public string Value { get; set; } 

    public XmlSchema GetSchema() 
    { 
     return null; 
    } 

    public void ReadXml(System.Xml.XmlReader reader) 
    { 
     this.Value = reader.ReadInnerXml(); 
    } 

    public void WriteXml(System.Xml.XmlWriter writer) 
    { 
     writer.WriteRaw(this.Value); 
    } 
} 
+0

+1, Wolałabym to w porównaniu z moim klasowym podejściem Root: IXmlSerializable. – VolkerK

Powiązane problemy