来自:http://blog.csdn.net/zx13525079024/article/details/7358223

关于AJAX调用WCF服务分为跨域和不跨域两种方式,今天咱们先介绍下不跨域下的调用方法。DEMO是在VS2008写的.

经过测试与研究,发现AJAX调用WCF服务必须满足以下条件

1.wcf的通讯方式必须使用webHttpBinding

2.必须设置<endpointBehaviors>节点的值

3.服务的实现必须添加

[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)] 标记

4.方法前面必须添加如下标记

[WebInvoke(Method = "POST",BodyStyle = WebMessageBodyStyle.Bare,ResponseFormat = Webmessageformat.Json)]

5.ajax方法中传递的参数名称必须和wcf服务中提供的参数方法名称一致

以下是本人写的代码,标记颜色的是需要注意的地方

服务器端配置文件代码

[html] view plain copy print ?
  1. <system.serviceModel>
  2. <services>
  3. <service name="WcfServiceDemoOne.Service1" behaviorConfiguration="WcfServiceDemoOne.Service1Behavior">
  4. <!-- Service Endpoints -->
  5. <endpoint address="" binding="webHttpBinding" contract="WcfServiceDemoOne.IService1" behaviorConfiguration="HttpBehavior"></endpoint>
  6. <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange"/>
  7. <host>
  8. <baseAddresses>
  9. <add baseAddress="http://localhost:12079/Service1.svc"/>
  10. </baseAddresses>
  11. </host>
  12. </service>
  13. </services>
  14. <behaviors>
  15. <serviceBehaviors>
  16. <behavior name="WcfServiceDemoOne.Service1Behavior">
  17. <!-- 为避免泄漏元数据信息,请在部署前将以下值设置为 false 并删除上面的元数据终结点-->
  18. <serviceMetadata httpGetEnabled="true"/>
  19. <!-- 要接收故障异常详细信息以进行调试,请将以下值设置为 true。在部署前设置为 false 以避免泄漏异常信息-->
  20. <serviceDebug includeExceptionDetailInFaults="false"/>
  21. </behavior>
  22. </serviceBehaviors>
  23. <endpointBehaviors>
  24. <behavior name="HttpBehavior">
  25. <webHttp/>
  26. </behavior>
  27. </endpointBehaviors>
  28. </behaviors>
  29. </system.serviceModel>



服务器端代码

[csharp] view plain copy print ?
  1. [ServiceContract]
  2. public interface IService1
  3. {
  4. [OperationContract]
  5. string GetData(int value);
  6. [OperationContract]
  7. City GetDataUsingDataContract(City composite);
  8. [OperationContract]
  9. List<City> GetList();
  10. [OperationContract]
  11. List<City> GetListData(List<City> list);
  12. }
  13. // 使用下面示例中说明的数据约定将复合类型添加到服务操作。
  14. [DataContract]
  15. public class City
  16. {
  17. int seq = 0;
  18. string cityID;
  19. string ctiyName;
  20. [DataMember]
  21. public string CityID
  22. {
  23. get
  24. {
  25. return cityID;
  26. }
  27. set
  28. {
  29. cityID=value;
  30. }
  31. }
  32. [DataMember]
  33. public string CityName
  34. {
  35. get { return ctiyName; }
  36. set { ctiyName = value; }
  37. }
  38. [DataMember]
  39. public int Seq
  40. {
  41. get
  42. { return seq; }
  43. set
  44. { seq = value; }
  45. }
  46. }


实现代码

[csharp] view plain copy print ?
  1. [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
  2. public class Service1 : IService1
  3. {
  4. [WebInvoke(Method = "POST",BodyStyle = WebMessageBodyStyle.WrappedRequest,RequestFormat = Webmessageformat.Json,ResponseFormat = Webmessageformat.Json)]
  5. public string GetData(int value)
  6. {
  7. return string.Format("You entered: {0}",value);
  8. }
  9. #region IService1 成员
  10. [WebInvoke(Method = "POST",ResponseFormat = Webmessageformat.Json)]
  11. public City GetDataUsingDataContract(City composite)
  12. {
  13. City c = new City();
  14. c.CityID = composite.CityID;
  15. c.CityName = composite.CityName;
  16. c.Seq = composite.Seq;
  17. return c;
  18. }
  19. [WebInvoke(Method = "POST",ResponseFormat = Webmessageformat.Json)]
  20. public List<City> GetList()
  21. {
  22. List<City> list = new List<City>();
  23. City cc = new City();
  24. cc.CityID = "1";
  25. cc.CityName="北京";
  26. cc.Seq = 3;
  27. list.Add(cc);
  28. City cc1 = new City();
  29. cc1.CityID = "2";
  30. cc1.CityName = "上海";
  31. cc1.Seq = 4;
  32. list.Add(cc1);
  33. return list;
  34. }
  35. [WebInvoke(Method = "POST",ResponseFormat = Webmessageformat.Json)]
  36. public List<City> GetListData(List<City> list)
  37. {
  38. return list;
  39. }
  40. #endregion
  41. }


客户端调用代码

[html] view plain copy print ?
  1. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WcfServiceDemoOne.WebForm1" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" >
  4. <head runat="server">
  5. <title></title>
  6. <script src="jquery-1.7.1.min.js" type="text/javascript"></script>
  7. <script type="text/javascript">
  8. //参数为整数的方法
  9. function fn1()
  10. {
  11. $.ajax({
  12. url: "http://localhost:12079/Service1.svc/GetData",
  13. type: "POST",
  14. contentType: "text/json",
  15. data: '{"value":2}',
  16. dataType: "json",
  17. success: function(returnValue) {
  18. alert(returnValue);
  19. },
  20. error: function() {
  21. alert('error');
  22. }
  23. });
  24. }
  25. //参数为实体类的方法
  26. function fn2() {
  27. $.ajax({
  28. url: "http://localhost:12079/Service1.svc/GetDataUsingDataContract",
  29. contentType: "application/json",
  30. data: '{"CityID":1,"CityName":"北京","Seq":"3"}',
  31. success: function(returnValue) {
  32. alert(returnValue.CityID + ' ' + returnValue.CityName + "--" + returnValue.Seq);
  33. },
  34. error: function() {
  35. alert('error');
  36. }
  37. });
  38. }
  39. //返回值为类集合的方法
  40. function fn3() {
  41. $.ajax({
  42. url: "http://localhost:12079/Service1.svc/GetList",
  43. type: "POST",
  44. contentType: "application/json",
  45. success: function(returnValue) {
  46. for (var i = 0; i < returnValue.length; i++) {
  47. alert(returnValue[i].CityID + ' ' + returnValue[i].CityName+'---'+returnValue[i].Seq);
  48. }
  49. },
  50. error: function() {
  51. alert('error');
  52. }
  53. });
  54. }
  55. function fn4() {
  56. $.ajax({
  57. url: "http://localhost:12079/Service1.svc/GetListData",
  58. data: '[{"CityID":1,"Seq":"3"},{"CityID":3,"CityName":"上海","Seq":"3"}]',
  59. dataType: "json",
  60. success: function(returnValue) {
  61. for (var i = 0; i < returnValue.length; i++) {
  62. alert(returnValue[i].CityID + ' ' + returnValue[i].CityName + '---' + returnValue[i].Seq);
  63. }
  64. },
  65. error: function() {
  66. alert('error');
  67. }
  68. });
  69. }
  70. </script>
  71. </head>
  72. <body>
  73. <form id="form1" runat="server">
  74. <div>
  75. <input id="Button1" type="button" value="调用1" onclick="fn1();" /></div>
  76. <input id="Button2" type="button" value="调用2" onclick="fn2();" />
  77. <br />
  78. <input id="Button3" type="button" value="调用3" onclick="fn3();" /></form>
  79. <br />
  80. <input id="Button4" type="button" value="调用4" onclick="fn4();"/>
  81. </body>
  82. </html>


demo下载地址:

http://download.csdn.net/detail/zx13525079024/4144097

ajax调用WCF服务的更多相关文章

  1. 应用程序关闭时的iOS任务

    我正在构建一个应用程序,通过ajax将文件上传到服务器.问题是用户很可能有时不会有互联网连接,并且客户希望在用户重新连接时安排ajax调用.这可能是用户在离线时安排文件上传并关闭应用程序.应用程序关闭时可以进行ajax调用吗?

  2. 从Android应用程序中消耗WCF Web服务?

    我想从Android应用程序中使用WCFWeb服务.我曾经使用过.asmxweb服务,但我不知道如何在Android应用程序中使用SCFWeb服务.我用谷歌搜索它但没有找到任何东西.如果有人做过,请帮助我.提前致谢.解决方法Hereisanarticleexplaininghowtoconsumewebservicewithandroidingeneral当涉及到WCF并且可以与您想要小心的jav

  3. android – Phonegap本地构建 – jquery ajax错误:readystate 0 responsetext status 0 statustext error

    解决方法您是否在索引文件中包含了内容安全元标记?

  4. Ajax简单的异步交互及Ajax原生编写

    一提到异步交互大家就会说ajax,仿佛ajax这个技术已经成为了异步交互的代名词.那下面将研究ajax的核心对象

  5. Ajax跨域问题的解决办法汇总(推荐)

    本文给大家分享多种方法解决Ajax跨域问题,非常不错具有参考借鉴价值,感兴趣的朋友一起学习吧

  6. ajax编写简单的登录页面

    这篇文章主要为大家详细介绍了ajax编写简单登录页面的具体代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  7. ajax从JSP传递对象数组到后台的方法

    今天小编就为大家分享一篇ajax从JSP传递对象数组到后台的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  8. 解决ajax返回验证的时候总是弹出error错误的方法

    这篇文章主要介绍了解决ajax返回验证的时候总是弹出error错误的方法,感兴趣的小伙伴们可以参考一下

  9. 使用AJAX完成用户名是否存在异步校验

    这篇文章主要介绍了使用AJAX完成用户名是否存在异步校验的相关资料,需要的朋友可以参考下

  10. ajax实现无刷新省市县三级联动

    这篇文章主要为大家详细介绍了ajax实现无刷新省市县三级联动的相关资料,利用三层架构实现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部