调用WCF REST服务时,使用JSON

四、JSON+ Wrapped

我们最后来演示Json消息格式在Wrapped风格下具有怎样的结构,为此我们只需要将应用在Create操作方法上的WebInvokeAttribute特性的BodyStyle属性设置为Wrapped。

   [ServiceContract]
    public interface IEmployees
   {
        //其他成员
        [WebInvoke(UriTemplate = "/", Method = "POST", 
        RequestFormat = WebMessageFormat.Json, 
        ResponseFormat = WebMessageFormat.Json, 
        BodyStyle = WebMessageBodyStyle.Wrapped)]
        Employee Create(Employee employee);
   }

如下面的代码所示,由于请求消息和回复消息采用Wrapped风格,表示Employee的JSON对象最终作为最终JSON对象的“employee”属性和“CreateResult”属性。(S1005)

请求消息主体:
{"employee":{"Department":"行政部","Grade":"G9","Id":"003","Name":"王五"}}
     
回复消息主体:
{"CreateResult":{"Department":"行政部","Grade":"G9","Id":"003","Name":"王五"}}

以上内容摘自 蒋老师的博客:http://www.cnblogs.com/artech/archive/2012/02/06/wcf-rest-web-message-body-style.html

下面是我自己遇到的问题:调用方传递过来的JSON数据,总是无法初始化为类实例,参数总是为null。后面才发现,如果使用

WebMessageBodyStyle.Wrapped

那么,JSON字符串里的最外层的属性,在上面的例子中是employee ,必须和服务中方法

Employee Create(Employee employee)

的参数相同。如下图所示:

转载于:https://www.cnblogs.com/xl0715/p/3433614.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值