Jquery以JSON方式调用WebService

 

  
    
< webServices >
< protocols >
< add name ="HttpPost" />
< add name ="HttpGet" />
</ protocols >
</ webServices >

 

 

今天测试了用jquery调用webservice,调用是没问题的,可是默认的webservice是返回给我们xml格式的,

这样对对于我们后续的操作很不方便,于是查找了 使用 json格式传送,始终没能够成功,后来参考了下 京东的 调用,终于知道原因所在了。。呵呵

 

 

Jquery以JSON方式调用WebService 

 

在webservice中需要添加如下节点(在 system.web节点下)

 

 

1、首先根据webservice类里面的提示修改
    
   
     
// 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
[System.Web.Script.Services.ScriptService]

 

2、然后在webservice中需要返回json数据的方法加上如下属性
     
   
     
[ScriptMethod(ResponseFormat = ResponseFormat.Json )]

   ScriptMethod在 using System.Web.Script.Services 命名空间下,这里还可以设置是否使用 get方式来调用 UseHttpGet=true

 

3、最后写jquery调用脚本

   
     
function doJSON() {
$.ajax({
url:
" http://localhost:11143/MyApplicationService.asmx/TestMethod " ,
data: {ssokey:
" ' " + ssokey + " ' " },
dataType:
" JSON " ,
contentType:
" application/json; charset=utf-8 " ,
success:
function (data) {
alert(data);
}
});
}

 

   这里有几个地方需要注意的,否则不成功

   a、data: {ssokey:"'" + ssokey + "'"}   -- 这里我传递了参数,需要这种写法,一定要写成 json对象,否则失败(这个地方折腾了好久。。。)

   b、dataType: "JSON" ---- 这里告诉 jquery 以 json格式传递

   c、ontentType: "application/json; charset=utf-8" --- 设置head 里面使用  json传递

上面三点都注意到以后就应该可以成功的调用并返回 json对象了

返回的json 对象是被保证在 d 对象中的,大家 alert一下就知道了,类似这种  

  {"d":"恭喜!认证成功!"}

 

 

上面就是今天“研究”的结果。。。

你可能感兴趣的:(webservice)