2009-06-29 28 views
9

我已經定義了以下類的XML字符串:我如何使用XmlSerializer的插入

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

,並創建了一個對象:當我使用XmlSerializer類序列化此對象

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

,它將返回xml:

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

如何使它不編碼我的XmlString內容,以便我可以將序列化的XML作爲

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

感謝, 伊恩

回答

1

我會感到非常驚訝,如果這是可能的。假設你有可能這樣做 - 如果你在這個屬性中有畸形的XML會發生什麼 - 所有的事情都會中斷。

我希望你或者需要爲這種情況編寫自己的序列化,或者使XmlString字段是一個包含foo字段的結構。

2

您可以(ab)使用IXmlSerializable interfaceXmlWriter.WriteRaw。但正如garethm指出的那樣,你幾乎必須編寫自己的序列化代碼。

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

打印

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

它也反序列化嗎? – configurator 2009-06-30 00:27:29

+0

如果您實現ReadXml(XmlReader reader)方法,那麼是的。 – VolkerK 2009-06-30 06:37:14

1

試試這個:

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

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

可以限制自定義序列化到這一點需要特別注意,像這樣的元素。

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); 
    } 
} 
相關問題