首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

jQuery调用WebService回来JSON数据

2013-03-16 
jQuery调用WebService返回JSON数据这要怎么办呢?继续看下面的JS代码,因为我们这里是调用的一个没能参数的W

jQuery调用WebService返回JSON数据

这要怎么办呢?继续看下面的JS代码,因为我们这里是调用的一个没能参数的WebService方法,所以我们可以提交一个空和JSON对象“{}",如下所示,设置data为{}。

    function fun1() {$.ajax({url: "WebService1.asmx/WS1",type: "POST",dataType: "json",contentType: "application/json; charset=utf-8",data: "{}",success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText);},complete: function(x) {alert(x.responseText);}});}

现在我再来看下图,可以看到,Content-Length已经为2了,并且也有Contetn-Type,还是我们设置的值,这样就能正确的返回JSON数据给我们使用了。

jQuery调用WebService回来JSON数据

还有一种方法就是:既然jquery不给我们设置Content-Type,我们可以自己设置,如下面的代码所示,我们在发送数据之前设置一下Content-Type为“application/json; charset=utf-8”,这样就可以了。

    function fun1() {$.ajax({url: "WebService1.asmx/WS1",type: "POST",dataType: "json",data: "",beforeSend: function(x) {x.setRequestHeader("Content-Type", "application/json; charset=utf-8");},success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText);},complete: function(x) {alert(x.responseText);}});}

下面是我们手工设置了Content-Type之后抓取的Request Headers,可以看到,即使Content-Length为0,里面也有了正确的Content-Type了。

jQuery调用WebService回来JSON数据

不过,需要注意的是:如果我们设置了jquery的contentType,又发送了一个空的JSON对象,并且还手工设置了Content-Type,就如下代码所示:

    function fun1() {$.ajax({url: "WebService1.asmx/WS1",type: "POST",dataType: "json",contentType: "application/json; charset=utf-8",data: "{}",beforeSend: function(x) {x.setRequestHeader("Content-Type", "application/json; charset=utf-8");},success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText);},complete: function(x) {alert(x.responseText);}});}

那么在IE发送的Requst Headers就如下图所示,你会看到Content-Type有两个用逗号隔开的值,这是为什么呢?因为,jquery为Content-Type设置了一次值,我们手工又设置一次,而在IE是多次设置Content-Type的值它会追加,而不是替换,不过这并不影响WebService正确返回JSON数据给我们,不过应该避免这种情况出现。

jQuery调用WebService回来JSON数据

如果说上面那种设置两次Content-Type的值还能正确的返回JSON数据,那么下面代码就不能正确返回JSON数据了。

    function fun1() {$.ajax({url: "WebService1.asmx/WS1",type: "POST",dataType: "json",data: "{}",beforeSend: function(x) {x.setRequestHeader("Content-Type", "application/json; charset=utf-8");},success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText);},complete: function(x) {alert(x.responseText);}});}

从下图可以看到Content-Type也有两个值,不过这个和上面那个还有点不一样,这次呢这个值是不一样的,一个是application/x-www-form-urlencoded,一个是application/json; charset=utf-8,这种情况就不能正确的返回JSON格式的数据了。这又是为什么呢?这是因为我们没有为jquery设置contentType为,并且又提交了一个空的JSON对象,可以为什么这样就会使用Content-Type出现这样的情况的呢?因为jquery的ajax用POST方法提交数据的时候,如果没有设置contentType,并且所发送的数据不为空,那么它就会为ContentType设置一个默认值,也就是application/x-www-form-urlencoded,所以就会出现这种情况了。

所以呢,在用POST方法请求的时候,如果有提交数据,也就是jquery ajax的datar属性不空的情况下(不为空的情况:1.发送一个空对象调用无参数的WebService方法;2.请一个有参数的WebService方法。),一定要设置contentType属性,并且不能手工设置Content-Type了。

jQuery调用WebService回来JSON数据

下面是请求有参数的WebService方法,一些情况在上面也都说过了,这里就不多说了。

不过有一点要注意,就是用POST方法请求的时候,不用手工去编码有汉字的参数值,如下面的data: "{s:'POST有参数'}",就不用写成data: "{s:"+encodeURI('POST有参数')+"}"了。

    function fun2() {$.ajax({url: "WebService1.asmx/WS2",contentType: "application/json; charset=utf-8",type: "POST",dataType: "json",data: "{s:'POST有参数'}",success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText); ;},complete: function(x) {alert(x.responseText);}});}

以上是我们说的用POST方法请求,下面是用GET方法请求。

下面是一个用GET方法请求一个无参数的WebService方法,不过这是一段错误的代码,错在哪儿呢,各们童鞋可以自己想一下,我们下面一起说。

    function fun3() {$.ajax({url: "WebService1.asmx/WS3",type: "GET",dataType: "json",data: "",contentType: "application/json; charset=utf-8",success: function(json) {alert(json.d);},error: function(x, e) {alert(x.responseText);},complete: function(x) {alert(x.responseText);}});}

下图是用上面一段代码请求所抓取的Request Headers,大家看一下,问题出在哪里。

jQuery调用WebService回来JSON数据

下面的代码是正确的用GET方法调用无参数的WebService方法。

        function fun3() {            $.ajax({                url: "WebService1.asmx/WS3",                dataType: "json",                data: "",                beforeSend: function(x) {                    x.setRequestHeader("Content-Type", "application/json; charset=utf-8");                },                success: function(json) {                    alert(json.d);                },                error: function(x, e) {                    alert(x.responseText);                },                complete: function(x) {                    alert(x.responseText);                }            });        }

下面的代码是正确的用GET方法调用有参数的WebService方法。

        function fun4() {            $.ajax({                url: "WebService1.asmx/WS4",                dataType: "json",                data: encodeURI("s='GET有参数'"),                beforeSend: function(x) {                    x.setRequestHeader("Content-Type", "application/json; charset=utf-8");                },                success: function(json) {                    alert(json.d);                },                error: function(x, e) {                    alert(x.responseText);                },                complete: function(x) {                    alert(x.responseText);                }            });        }

下图是正确的用GET方法(有参数和无参数)调用WebService方法所抓取的Request Headers。

jQuery调用WebService回来JSON数据

从上图可以看到,用GET方法请求,不管是有参数还是无参数,都是没有Content-Length的,所以jquery也就不能为我们设置Content-Type了,我只能手工设置Content-Type,所以我们也就没有必要设置jquery ajax的contentType了。

需要注意的是,GET方法与POST方法不同,有参数的时候,如果参数的值不是ASCII字符,要用encodeURI编一下码,要不服务端接收到的数据为乱码。

?

相关代码地址:http://download.csdn.net/source/1510113。

热点排行