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. Linux 比较判断运算(if test)

    200 ? "200px" : this.width)!important;} --> 介绍 本篇文章主要是列举在shell命令中常出现的一些用来做比较的运算符,这些运算符是 ...

  2. Window Ghosting

    最近工作中遇到Window Ghosting这个问题, 感觉挺有意思,这里简单记录下. 在XP时代我们的程序没有响应后只能通过任务管理器强制杀掉,但是Vista之后情况变了, 我们仍然可以拖动失去响应 ...

  3. js模版引擎handlebars.js实用教程——另一种Helper用法

    返回目录 <!DOCTYPE html> <html> <head> <META http-equiv=Content-Type content=" ...

  4. Java枚举类型getClass和getDeclaringClass区别(未完待续)

    Java中的枚举类型有getClass()和getDeclaringClass()两个方法,在通常情况下这两个方法返回的类型一样,在某些场景下会有不同的表现 参照 http://stackoverfl ...

  5. Oracle日期时间函数大全

    ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year: yy two digits 两位年 显示值:07 yyy three digits ...

  6. atitit.js浏览器环境下的全局异常捕获

    atitit.js浏览器环境下的全局异常捕获 window.onerror = function(errorMessage, scriptURI, lineNumber) { var s= JSON. ...

  7. Atitit.会员卡(包括银行卡)api的设计

    Atitit.会员卡(包括银行卡)api的设计 1. 银行卡的本质是一种商业机构会员卡1 2. 会员卡号结构组成1 2.1. ●前六位是:发行者标识代码 Issuer Identification N ...

  8. eclipse打包apk

    eclipse打包apk

  9. Java 线程 — AbstractQueuedSynchronizer

    锁 锁就是一种状态,比如互斥锁:同一时间只能有一个线程拥有,可以使用一个整型值来标志当前的状态 0:表示没有现成占有锁 1:表示锁已经被占用 AbstractQueuedSynchronizer 实现 ...

  10. Ext.Net常用方法

    1.js(Ext)操作 Ext.Msg.alert('系统提示', '未连接血站,该功能暂时不能使用.'); Ext.getCmp("id").getValue();Ext.get ...