跨平台调用wcf
WebInvokeAttribute
BodyStyle:获取和设置传入与传出服务操作的消息的正文样式 ,该属性的值是以下类型
public enum WebMessageBodyStyle
成员名称 说明
Bare 不包装请求和响应。
Wrapped 包装请求和响应。
WrappedRequest 包装请求,但不包装响应。
WrappedResponse 包装响应,但不包装请求。
当服务或客户端将参数和返回值序列化为消息时,会将它们写入基础结构提供的 XML 元素中。这些 XML 元素被称为 “包装” 值。有时开发商不想包装序列化值周围的这些额外 XML 元素。 WebMessageBodyStyle 枚举会指定是否包装参数和返回值。
将此枚举与 WebGetAttribute 和 WebInvokeAttribute 搭配使用,可控制传入与传出服务操作的数据如何显示在网络上。上述两个属性都默认为 Bare。
ResponseFormat:此属性会确定从服务操作发出的响应的格式。可能的值为 Xml 和 Json。
Method :获取和设置服务操作响应的协议(如 HTTP)方法。该属性默认的是POST,也可以指定GET方式
UriTemplate:用于服务操作的统一资源标识符 (URI) 模板。
[OperationContract] [WebInvoke(BodyStyle = WebMessageBodyStyle.Wrapped, RequestFormat = WebMessageFormat.Xml, ResponseFormat = WebMessageFormat.Json, Method = "GET" , UriTemplate = "/Test/{ID}/{Name}")] DataModel Test(string ID, string Name);
服务的实现类:
public DataModel Test(string ID,string Name) { return new DataModel() { ID =Convert.ToInt16(ID), Name = Name }; }
DataModle的原型是:
上面是在服务契约中增加了一个方法Test,该方法是有两个参数,为了能在浏览器中演示出来,method那里我们设置了Get的方式, UriTemplate = "/Test/{ID}/{Name}". UriTemplate这样设置,就可以直接在地址参数里面设置test的参数了。具体调用方式如下:
我们看到服务返回来的数据格式是基于xml的,下面将ResponseFormat格式改成json,
服务器返回的是json格式的。
需要额外注意的是服务的配置,
要用webHttpBinding