JSONP(JSON with Padding)可以看成是JSON的一种“使用模式”,用以解决“跨域访问”的问题,这篇简单的文章给出一个简单的例子用于模拟如何通过jQuery以JSONP的访问调用一个WCF REST服务。[源代码从这里下载]

在这个例子中,我们将定义一个用于返回所有员工信息的服务,下面是用于表示员工信息的Employee的类型和契约接口。契约接口IEmployees的GetAll操作用以返回所有员工列表,我们指定了Uri模板并将回复消息格式设置为JSON。

   1: using System.Collections.Generic;

   2: using System.ServiceModel;

   3: using System.ServiceModel.Web;

   4: namespace Artech.WcfServices.Service.Interface

   5: {

   6:     [ServiceContract]

   7:     public interface IEmployees

   8:     {

   9:         [WebGet(UriTemplate = "all",ResponseFormat =WebMessageFormat.Json)]      

  10:         IEnumerable<Employee> GetAll();

  11:     }

  12:     public class Employee

  13:     {

  14:         public string Id { get; set; }

  15:         public string Name { get; set; }

  16:         public string Department { get; set; }

  17:         public string Grade { get; set; }

  18:     }

  19: }

在如下所示的服务类型EmployeesService 中,我们直接让服务操作GetAll返回一个包含3个Employee对象的列表。

   1: using System.Collections.Generic;

   2: using Artech.WcfServices.Service.Interface;

   3: namespace Artech.WcfServices.Service

   4: {

   5:     public class EmployeesService : IEmployees

   6:     {

   7:         public IEnumerable<Employee> GetAll()

   8:         {

   9:             return new List<Employee>

  10:             {

  11:                 new Employee{ Id = "001", Name="张三", Department="开发部", Grade = "G6"},    

  12:                 new Employee{ Id = "002", Name="李四", Department="人事部", Grade = "G7"}, 

  13:                 new Employee{ Id = "003", Name="王五", Department="销售部", Grade = "G8"}

  14:             };

  15:         }

  16:     }

  17: }

我们通过控制台程序对服务进行寄宿。从下面的配置可以看到我们采用了标准终结点WebHttpEndpoint。为了让服务具有跨域支持的能力,我们必须将标准终结点的crossDomainScriptAccessEnabled属性设置为True。WebHttpBinding也具有同名的属性,如果直接使用WebHttpBinding也需要将该属性设置为True。

   1: <configuration>

   2:   <system.serviceModel>

   3:     <standardEndpoints>

   4:       <webHttpEndpoint>

   5:         <standardEndpoint crossDomainScriptAccessEnabled="true"/>

   6:       </webHttpEndpoint>

   7:     </standardEndpoints>

   8:     <bindings>

   9:       <webHttpBinding>

  10:         <binding crossDomainScriptAccessEnabled="true" />

  11:       </webHttpBinding>

  12:     </bindings>

  13:     <services>      

  14:       <service name="Artech.WcfServices.Service.EmployeesService">

  15:         <endpoint kind="webHttpEndpoint" 

  16:                   address="http://127.0.0.1:3721/employees"

  17:                   contract="Artech.WcfServices.Service.Interface.IEmployees"/>

  18:       </service>

  19:     </services>

  20:   </system.serviceModel>

  21: </configuration>

在客户端,我们在一个Web页面中通过jQuery进行Ajax调用这个服务,并将得到的员工列表显示在一个表格中。出CSS之外的页面代码如下所示,需要注意的是在进行Ajax调用的使用将dataType选项设置成“jsonp”,而不是“json”。

   1: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

   2: <html xmlns="http://www.w3.org/1999/xhtml">

   3:   <head>

   4:     <title>员工列表</title>

   5:     <style type="text/css">

   6:        ...

   7:     </style>

   8:     <script src="Scripts/jquery-1.7.1.js" type="text/javascript"></script>

   9:     <script type="text/javascript">

  10:         $(function () {

  11:             $.ajax({

  12:                 type: "get",

  13:                 url: "http://127.0.0.1:3721/employees/all",

  14:                 dataType: "jsonp",

  15:                 success: function (employees) {

  16:                     $.each(employees, function (index, value) {

  17:                         var detailUrl = "detail.html?id=" + value.Id;

  18:                         var html = "<tr><td>";

  19:                         html += value.Id + "</td><td>";

  20:                         html += "<a href='" + detailUrl + "'>" + value.Name + "</a></td><td>";

  21:                         html += value.Grade + "</td><td>";

  22:                         html += value.Department + "</td></tr>";

  23:                         $("#employees").append(html);

  24:                     });

  25:                     $("#employees tr:odd").addClass("oddRow");

  26:                 }

  27:             });

  28:         });

  29:      </script>

  30:   </head>

  31:   <body>

  32:     <table id="employees" width="600px">

  33:         <tr>

  34:             <th>ID</th>

  35:             <th>姓名</th>

  36:             <th>级别</th>

  37:             <th>部门</th>

  38:         </tr>

  39:     </table>

  40: </body>

  41: </html>

当服务启动后在浏览器中显示上面这个Web页面,会得到如下所示的员工列表。

一个通过JSONP跨域调用WCF REST服务的例子(以jQuery为例)的更多相关文章

  1. 实现jquery.ajax及原生的XMLHttpRequest跨域调用WCF服务的方法

    关于ajax跨域调用WCF服务的方法很多,经过我反复的代码测试,认为如下方法是最为简便的,当然也不能说别人的方法是错误的,下面就来上代码,WCF服务定义还是延用上次的,如: namespace Wcf ...

  2. jquery跨域调用wcf

    使用jquery跨域调用wcf服务的时候会报如下错误 $.ajax({ url: 'http://localhost:28207/Service1.svc/GetData', method: 'get ...

  3. jsonP跨域调用

    -------------------------------------jsonP跨域调用------------------------------------- <div class=&q ...

  4. jquery中的jsonp跨域调用

                                                    jquery jsonp跨域调用接口

  5. jquery中的jsonp跨域调用(接口)

                                                                           jquery jsonp跨域调用接口

  6. jquery ajax jsonp跨域调用实例代码

    今天研究了AJAX使用JSONP进行跨域调用的方法,发现使用GET方式和POST方式都可以进行跨域调用,这里简单分享下,方便需要的朋友 客户端代码 复制代码 代码如下: <%@ Page Lan ...

  7. 使用jsonp跨域调用百度js实现搜索框智能提示,并实现鼠标和键盘对弹出框里候选词的操作【附源码】

    项目中常常用到搜索,特别是导航类的网站.自己做关键字搜索不太现实,直接调用百度的是最好的选择.使用jquery.ajax的jsonp方法可以异域调用到百度的js并拿到返回值,当然$.getScript ...

  8. 使用jsonp跨域调用百度js实现搜索框智能提示(转)

    http://www.cnblogs.com/oppoic/p/baidu_auto_complete.html 项目中常常用到搜索,特别是导航类的网站.自己做关键字搜索不太现实,直接调用百度的是最好 ...

  9. ASP.NET Web API 自定义MediaType实现jsonp跨域调用

    代码来自<ASP.NET Web API 2 框架揭秘>一书. 直接上代码: /// <summary> /// 自定义jsonp MediaType /// </sum ...

随机推荐

  1. zendframework 2

    我想我的生活需要新的挑战 zf2整个框架里面都应用了namespace,并且他的每个模块,我们都可以根据自己的需要去命名路径,对我来说,zf2的模块化更加的清晰,对于外包来说,或许很方便. 创建他,我 ...

  2. merge sort and quick sort 自己去理解吧

    <?php $digits=array(,,,,,,,); function quickSort($arr){ $len=count($arr); ){ return $arr; } $midK ...

  3. 知方可补不足~SQL2008中的发布与订阅模式~续

    回到目录 上一回介绍了如何在sql2008中建立一个数据库的发布者,今天来说一下如何建立一个订阅者,其实订阅者也是一个数据库,而这个数据库是和发布者的数据结构相同的库,它们之间通过SQL代理进行数据上 ...

  4. 搭建jekyll博客

    使用jekyll将markdown文件生成静态的html文件,并使用主题有序的进行布局,形成最终的博客页面. 特点 基于ruby 使用Markdown书写文章 无需数据库 可以使用GitHub Pag ...

  5. Atitit jsr规范有多少个  407个。Jsr规范大全

    Atitit jsr规范有多少个  407个.Jsr规范大全 1.1. JCP维护职能是发展和更新.1 1.2. Java技术规范.参考实现(RI).技术兼容包(TCK)1 1.3. JCP维护的规范 ...

  6. SSH+JPA查询两个数据库

    1.第一步导包: 1.struts2包: 2.spring包: 3.hibernate包: 4.数据库包: 2.web.xml配置 3.struts2的配置: 1.struts.xml 2.s001. ...

  7. Win7系统.net framework 4.0没有注册导致部署在IIS的站点跑不起来怎么办

    win7装了VS再装IIS,结果IIS里面有.NET4.0,但是程序始终是跑不起来,怎么办呢? 分析觉得可能是因为4.0没有注册到IIS,在win7下如果先安装vs2010 (附带会安装Microso ...

  8. 通过bootstrap来学习less

    很早之前就听说过less了,但是一直拖着没去学习.最近抽空看了less,其实语法很简单,看一遍基本就知道怎么用了.平时自己写页面用less的话,感觉是方便了些,但是难道less的好处就只是这样? 刚好 ...

  9. 优化与扩展Mybatis的SqlMapper解析

    接上一篇博文,这一篇来讲述怎么实现SchemaSqlMapperParserDelegate——解析SqlMapper配置文件. 要想实现SqlMapper文件的解析,还需要仔细分析一下mybatis ...

  10. 体验Visual Studio 2015 Windows Forms应用程序开发与维护

    昨天到半夜还没有等到Visual Studio 2015的下载地址,实在熬不住就先休息了.北美地区的时区比北京时间要晚一些,今天早上到公司就看到Visual Studio 2015的下载地址,迅速的将 ...