2009-06-29 64 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); 
    } 
} 
相关问题