zoukankan      html  css  js  c++  java
  • How to expose a JSON endpoint from a WCF-service

    Having seen the small footprint set by JSON – I’ve begun using it extensively for mobile device (WP7) communication. In particular the phone scenario makes it desirable to have an as small as possible data load to transfer between server and device. When using the JSON formatting, you can really minimize the load as documented here. Below is what is returned in JSON-format (compare that to the verbose OData or SOAP formatting!):

    [{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"}]

    How to do ?
    To expose a WCF-implemented service with JSON support, you need to setup these artifacts:

    Service Contract:
    First define the contract for the service to expose.

    namespace WebService1
    {
        [ServiceContract(Namespace="http://someethingelse.com")]
        public interface IEmployeeService
        {
            [OperationContract]
            [WebInvoke(BodyStyle=WebMessageBodyStyle.Bare, ResponseFormat=WebMessageFormat.Json)]
            Employee[] GetAll_POST();
    
            [OperationContract]
            [WebGet(BodyStyle = WebMessageBodyStyle.Bare, ResponseFormat = WebMessageFormat.Json)]
            Employee[] GetAll_GET();
        }
    
        [DataContract(Namespace="http://somethingunique.com")]
        public class Employee
        {
            [DataMember]
            public int BirthYear { get; set; }
            [DataMember]
            public string FirstName { get; set; }
            [DataMember]
            public string LastName { get; set; }
        }
    }
    

      

    Note the WebInvoke and WebGet attributes on the service definition. The WebInvoke attribute specifies that the method will obey POST-requests, where as the WebGetattribute will make the method obey GET-requests.

    The two attributes takes parameters that allows for specifying in which format the data should be formatted. When the ResponseFormat=WebMessageFormat.Json is set, the data returned by the method is formatted as a clean and simple JSON notation.

    Web.config
    Of-course you also need to setup configuration in the web.config. Here you should pay special attention to the binding and the behaviorConfiguration attributes.
    Important: In particular the endpointBehavior should have <webHttp> set as content to gain the clean JSON formatting (see below).

      <system.serviceModel>
        <services>
          <service name="WebService1.EmployeeService">
            <endpoint name="jsonEP"
                      address=""
                      binding="webHttpBinding"
                      behaviorConfiguration="json"
                      contract="WebService1.IEmployeeService"/>
          </service>
        </services>
        <behaviors>
          <endpointBehaviors>
            <behavior name="json">
              <webHttp/>
            </behavior>
          </endpointBehaviors>
        </behaviors>
      </system.serviceModel>
    

      

    Client:
    When calling the above service, you will receive a nicely formatted JSON string like this:

    [{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"},{"BirthYear":1900,"FirstName":"Anders","LastName":"And"}]

    That’s how easy it is setting up when using WCF.

    http://blog.clauskonrad.net/2010/11/how-to-expose-json-endpoint-from-wcf.html

  • 相关阅读:
    数据库备份与还原
    启明星产品与微软Active Directory活动目录集成说明
    启明星请假系统里,计算工作日的实现
    启明星会议室预定系统Outlook版开始支持Exchange2013与Office365版
    Jquery Mobile实例--利用优酷JSON接口读取视频数据
    高性能且线程安全的两种格式化日期方式
    将数列唯一值化后再求中值的效率比较 第一方案胜出,加索引后在近两百万数据中查出中值耗时0.176秒
    Oracle WITH 语句 语法
    新三种求数列中值SQL之效率再比拼
    rank,dense_rank和row_number函数区别
  • 原文地址:https://www.cnblogs.com/wzihan/p/14737572.html
Copyright © 2011-2022 走看看