用jQuery AJAX调用WCF服务

  在网络上经常看到一些初学者提问怎么在AJAX中或用Javascript调用WCF服务,本文将简要给初学者介绍如何在AJAX中或用Javascript调用WCF服务以及注意事项。为了便于讲解,我们首先创建一个WCF服务,服务和服务数据定义如下:

    //数据契约    [DataContract]    public class Person    {        [DataMember]        public int ID { get; set; }        [DataMember]        public string Name { get; set; }    }    //WCF服务,为了能使js调用,必须设置ASPNETCompatibilityRequirements为Allowed或Required    [ServiceContract(Namespace = "")]    [ASPNETCompatibilityRequirements(RequirementsMode = ASPNETCompatibilityRequirementsMode.Allowed)]    public class PersonService    {        //服务功能1        [OperationContract]        [WebGet]        public Person GetOnePerson()        {            return new Person { ID = 1, Name = "cokkiy" };        }        //服务功能2        [OperationContract]        [WebGet]        public List<Person> GetPorsons(int id, string name)        {            return new List<Person>() { new Person { ID=1,Name="cokkiy"},                 new Person { ID=id,Name=name} };        }    }

  Ok,我们先看一下服务定义,为了使AJAX或JS调用服务,必须标记服务的ASPNET兼容模式为Allowed或Required。其次,操作契约必须标记为WebGet或WebInvoke,WebGet属性标记了一个可以用http get方法调用的操作,而WebInvoke属性标记了一个可以用http post方法调用的操作。

  再来看服务配置文件:

<system.serviceModel>        <behaviors>            <endpointBehaviors>                <behavior name="AjaxWCFWeb.Services.PersonServiceASPNETAjaxBehavior">                    <enableWebScript/>                behavior>            endpointBehaviors>        behaviors>        <serviceHostingEnvironment ASPNETCompatibilityEnabled="true"/>        <services>            <service name="AjaxWCFWeb.Services.PersonService">                <endpoint address="" behaviorConfiguration="AjaxWCFWeb.Services.PersonServiceASPNETAjax
Behavior
" binding="webHttpBinding"
contract="AjaxWCFWeb.Services.PersonService"/> service> services> system.serviceModel>

  这里注意,配置文件中,必须提供基于webHttpBinding的绑定,否则就不能从js中调用。并且,必须设置serviceHostingEnvironment ASPNETCompatibilityEnabled

  下面来看如何在js中调用我们刚才创建的WCF服务,我们用JQuery的ajax功能。

    <p>       <button id="getOnePerson" type="button">Get One Personbutton>       <button id="getPersons" type="button">Get Personsbutton>    p>    <script type="text/Javascript">        $(document).ready(function() {            $('#getOnePerson').click(function() {                $.getJSON("/Services/PersonService.svc/GetOnePerson", {}, function(data) {                    alert("ID:" + data.d.ID + " Name:" + data.d.Name);                });            });            $('#getPersons').click(function() {                $.getJSON("/Services/PersonService.svc/GetPorsons", { id: 100, name: "from clent" }, function
(data) { alert(data.d.length); for (var i = 0; i < data.d.length; i++) { alert("ID:" + data.d[i].ID + " Name:" + data.d[i].Name); } }); }); }); script>

  由于我们用的是JQuery的AJAX函数,因此调用方式非常简单,熟悉JQuery AJax的朋友一看就明白了,这种调用方式跟调用其他方法几乎完全一样,差别在于返回的数据,请注意我们真正的数据在data.d中。

  总结:1)WCF服务必须标记为ASPNETCompatibilityRequirements为Alowed或Requered。

           2)服务中的操作(Operation)必须标记为WebGet或WebInvoke。

           3)服务配置中必须提供webHttpBinding绑定,并设置服务的运行环境为ASPNETCompatibilityEnabled

           4)返回的数据在属性d中。

it知识库用jQuery AJAX调用WCF服务,转载需保留来源!

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。