3

我有一个场景,其中请求对象被 XML 序列化并发送回 TCP 服务器以进行处理。序列化由遗留框架完成。不用说,我无法在遗留框架中进行更改。然而,遗留框架足够智能,可以意识到请求对象是否正在实现IXmlSerializable,在这种情况下,它需要接口的 WriteXml 方法来进行序列化。我想最大限度地控制我手中的 serailzation 过程,因此我这样编写了我的 RequestBase 类:

  public abstract class RequestBase : IXmlSerializable
  {
    [XmlElement("Environment")]
    public string BaseEnvironment { get; set; }

    protected RequestBase()
    {
    }

    protected RequestBase(string environment, string image):this()
    {
      HaloEnvironment = environment;       
    }


    XmlSchema IXmlSerializable.GetSchema()
    {
      return null;
    }

    void IXmlSerializable.ReadXml(XmlReader reader)
    {
      throw new NotImplementedException();
    }

    void IXmlSerializable.WriteXml(XmlWriter writer)
    {
      WriteXml(writer);
    }   

    protected virtual void WriteXml(XmlWriter writer)
    {

    }

  }

这门课就像人们想象的那样简单。任何请求对象都必须实现它。一个示例请求类是这样的:

  [XmlRoot("MyCuteRoot")]
  public class CuteRequest : RequestBase
  {

    public string CuteName { get; set; }

    public CuteRequest ()
    {
    }


    protected override void WriteXml(XmlWriter writer)
    {
      writer.WriteStartElement("Parameters");
      writer.WriteStartElement("header");

      if (!string.IsNullOrWhiteSpace(BaseEnvironment ))
        writer.WriteElementString("Environment", BaseEnvironment );


      if (!string.IsNullOrWhiteSpace(CuteName ))
        writer.WriteElementString("CuteNode", CuteName );

      writer.WriteEndElement();//header
      writer.WriteEndElement();//Parameters
    }
 }

上面的类给了我以下Xml:

<MyCuteRoot>
        <Parameters>
          <header>
            <Environment>Developer</Environment>
            <CuteNode>a2</CuteNode>
          </header>
        </Parameters>
      </MyCuteRoot>

到目前为止,太阳一直很亮,我很高兴这能奏效。然后出现了一个场景,后端服务器开始期待它称为BulkRequest的东西。现在的请求将被集成为集合。

我尝试使用以下 BulkRequest 类处理这种情况:

  public class BulkRequest:RequestBase
  {

    public IEnumerable<RequestBase> Requests { get; private set; }

    public BulkRequest(IEnumerable<RequestBase> requests)
    {
      if (requests == null)
        throw new ArgumentNullException("requests");
      Requests = requests;
    }

    public BulkRequest()
    {
    }

    protected override void WriteXml(XmlWriter writer)
    {
      foreach (RequestBase requestBase in Requests)
      {
        (requestBase as IXmlSerializable).WriteXml(writer);
      }
    }
  }

现在这行不通。我想要一个如下的xml:

<STPRequest>
      <MyCuteRequest>
       <Parameters>
          <header>
            <Environment>Developer</Environment>
            <CuteName>a2</CuteName>
          </header>
        </Parameters>
      </MyCuteRequest>
      <MyCuteRequest>
        <Parameters>
          <header>
            <Environment>Developer</Environment>
            <CuteName>a2</CuteName>
          </header>
        </Parameters>
      </MyCuteRequest>
</STPRequest>

这是针对批量请求中存在的两个 CuteRequest 对象。但我得到以下xml:

<STPRequest>
  <BulkRequest>
    <Parameters>
      <header>
        <Environment>Developer</Environment>
        <CuteName>a2</CuteName>
      </header>
    </Parameters>
    <Parameters>
      <header>
        <Environment>Developer</Environment>
        <CuteName>a2</CuteName>
      </header>
    </Parameters>
  </BulkRequest>
</STPRequest>

问题有两个:

  • 如何摆脱强迫自己进入的“ BulkRequest ”标签。

  • 如何使项目(即 MyCuteRequest)的 XmlRoot 值出现在 Xml 中(包含每个参数标记。)

感谢您耐心阅读到这里。任何帮助将不胜感激,因为几个小时的谷歌搜索证明是徒劳的。

问候,

4

0 回答 0