与 POX 应用程序的互操作性

“纯旧式 XML”(POX) 应用程序通过交换原始 HTTP 消息进行通信,这些消息仅包含未封装在 SOAP 信封内的 XML 应用程序数据。 Windows Communication Foundation (WCF) 可以同时提供使用 POX 消息的服务和客户端。 就服务而言,可以使用 WCF 实现向客户端(例如,发送和接收 POX 消息的 Web 浏览器和脚本语言)公开终结点的服务。 就客户端而言,可以使用 WCF 编程模型实现与基于 POX 的服务进行通信的客户端。

备注

本文档最初是针对 .NET Framework 3.0 编写的。 .NET Framework 3.5 具有对使用 POX 应用程序的内置支持。 有关详细信息,请参阅 WCF Web HTTP 编程模型

使用 WCF 进行 POX 编程

使用 POX 消息通过 HTTP 进行通信的 WCF 服务使用 <customBinding>

<customBinding>
   <binding name="poxServerBinding">
       <textMessageEncoding messageVersion="None" />
       <httpTransport />
   </binding>
</customBinding>

此自定义绑定包含两个元素:

标准 WCF 文本消息编码器专门配置为使用 None 值,从而使其可以处理未封装在 SOAP 信封内到达的 XML 消息有效负载。

使用 POX 消息通过 HTTP 进行通信的 WCF 客户端使用类似的绑定(如下面的命令性代码所示)。

private static Binding CreatePoxBinding()
{
    TextMessageEncodingBindingElement encoder =
        new TextMessageEncodingBindingElement( MessageVersion.None, Encoding.UTF8 );
    HttpTransportBindingElement transport = new HttpTransportBindingElement();
    transport.ManualAddressing = true;
    return new CustomBinding( new BindingElement[] { encoder, transport } );
}

因为 POX 客户端必须显式指定将消息发送到的 URI,所以它们通常必须将 HttpTransportBindingElement 配置为手动寻址模式,方法是将该元素的 ManualAddressing 属性设置为 true。 这样,应用程序代码就可以对消息进行显式寻址,因此,当应用程序将消息发送到不同的 HTTP URI 时,不必每次都创建一个新的 ChannelFactory

因为 POX 消息不使用 SOAP 标头传送重要的协议信息,所以 POX 客户端和服务通常必须操作用于发送或接收消息的基础 HTTP 请求片段。 HTTP 特定的协议信息(例如 HTTP 标头和状态代码)通过以下两个类显示在 WCF 编程模型中:

下面的代码示例演示如何创建一条发送到 http://localhost:8100/customers 的 HTTP GET 请求消息。

Message request = Message.CreateMessage( MessageVersion.None, String.Empty );
request.Headers.To = "http://localhost:8100/customers";

HttpRequestMessageProperty property = new HttpRequestMessageProperty();
property.Method = "GET";
property.SuppressEntityBody = true;
request.Properties.Add( HttpRequestMessageProperty.Name, property );

首先,通过调用 Message 创建一个空请求 CreateMessage(MessageVersion, String)None 参数用于指示 SOAP 信封不是必需的并且 Empty 参数作为 Action 传递。 然后,通过将 To 标头设置为所需的 URI,对请求消息进行寻址。 接下来,创建一个 HttpRequestMessageProperty,并将 Method 设置为 HTTP 谓词 GET 方法,将 SuppressEntityBody 设置为 true,以指示不应在传出 HTTP 请求消息的消息正文中发送任何数据。 最后,将请求属性添加到请求消息的 Properties 集合中,以便它能影响 HTTP 传输协议发送该请求的方式。 这样,该消息就准备好通过 IRequestChannel 的相应实例进行发送了。

可以对服务使用类似的技术,以便从传入的消息中提取 HttpRequestMessageProperty 并构造响应。