jQuery中通过ajax调用webservice传递数组参数的问题实例详解


Posted in Javascript onMay 20, 2016

下面通过实例给大家说明比较直观些,更方便大家了解。

本人的项目中通过jquery.ajax调用webservice.

客户端代码如下:

$.ajax({
url: "test/xxx.asmx",
type: 'POST',
dataType: 'xml',
timeout: ,
data: { name: "zhangsan", tags: ["aa", "bb", "cc"] },
error: function(xml) {
alert(xml.responseText);
},
success: function(xml) {
alert("OK");
}
});

服务端代码如下:

[WebMethod]
public XmlDocument xxx(string name, string [] tags )
{ 
return sth; 
}

总是抛出异常.

问题出现在这里:

下面是HTTP数据:

POST http://xxx.com/xxx.asmx/xxx HTTP/1.1
Host: center.cmis.htpc.com.cn
Connection: keep-alive
Content-Length: 55
Cache-Control: max-age=0
Origin: http://xxx.com
User-Agent: Mozilla/5.0 (Windows NT 5.1) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.186 Safari/535.1
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Accept: application/xml, text/xml, */*; q=0.01
Referer: http://xxx.com/xxx.aspx
Accept-Encoding: gzip,deflate,sdch
Accept-Language: zh-CN,zh;q=0.8
Accept-Charset: GBK,utf-8;q=0.7,*;q=0.3
name=zhangsan&tags%5B%5D=aa&tags%5B%5D=bb&tags%5B%5D=cc

而它期望的格式是如下的:

POST /xxx.asmx/xxx HTTP/1.1
Host: xxx.com
Content-Type: application/x-www-form-urlencoded
Content-Length: length
name=string&tags=string&tags=string

比较上面粗体,post的数据除了问题. 正确的应该如下:

name=zhangsan&tags=aa&tags=bb&tags=cc

看来问题出在jquery.ajax上面了.见代码(jquery.1.8.3.js)

function buildParams(prefix, obj, traditional, add) {
var name;
if (jQuery.isArray(obj)) { 
// Serialize array item.
jQuery.each(obj, function(i, v) {
if (traditional || rbracket.test(prefix)) { 
// Treat each array item as a scalar.
add(prefix, v);
} else {
// If array item is non-scalar (array or object), encode its
// numeric index to resolve deserialization ambiguity issues.
// Note that rack (as of ..) can't currently deserialize
// nested arrays properly, and attempting to do so may cause
// a server error. Possible fixes are to modify rack's
// deserialization algorithm or to provide an option or flag
// to force array serialization to be shallow.
//ytx 
buildParams(prefix, v, traditional, add);
//buildParams(prefix + "[" + (typeof v === "object" ? i : "") + "]", v, traditional, add);
}
});
} else if (!traditional && jQuery.type(obj) === "object") {
// Serialize object item.
for (name in obj) {
buildParams(prefix + "[" + name + "]", obj[name], traditional, add);
}
} else {
// Serialize scalar item.
add(prefix, obj);
}
}

结论:

出问题的代码在22行,我修改成21行那样就行了.

不过,我对js/jquery都是一知半解的,希望不要引起别的后遗症,呵呵.

以上所述是小编给大家介绍的jQuery中通过ajax调用webservice传递数组参数的问题实例详解的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript算符的优先级介绍
Mar 20 Javascript
JS实现图片横向滚动效果示例代码
Sep 04 Javascript
javascript屏蔽右键代码
May 15 Javascript
jQuery创建自定义的选择器用以选择高度大于100的超链接实例
Mar 18 Javascript
SWFObject基本用法实例分析
Jul 20 Javascript
javascript+canvas实现刮刮卡抽奖效果
Jul 29 Javascript
第六篇Bootstrap表格样式介绍
Jun 21 Javascript
详解Vue 开发模式下跨域问题
Jun 06 Javascript
基于AngularJS实现的工资计算器实例
Jun 16 Javascript
关于vue-router的那些事儿
May 23 Javascript
Makefile/cmake/node-gyp中区分判断不同平台的方法
Dec 18 Javascript
vue中template的三种写法示例
Oct 21 Javascript
浅析JavaScript Array和string的转换(推荐)
May 20 #Javascript
深入理解JS addLoadEvent函数
May 20 #Javascript
用jQuery获取table中行id和td值的实现代码
May 19 #Javascript
jquery遍历table的tr获取td的值实现方法
May 19 #Javascript
jquery if条件语句的写法
May 19 #Javascript
laypage分页控件使用实例详解
May 19 #Javascript
js多功能分页组件layPage使用方法详解
May 19 #Javascript
You might like
分页显示Oracle数据库记录的类之一
2006/10/09 PHP
php中常用的预定义变量小结
2012/05/09 PHP
解析PHP生成静态html文件的三种方法
2013/06/18 PHP
thinkphp实现上一篇与下一篇的方法
2014/12/08 PHP
laravel框架中控制器的创建和使用方法分析
2019/11/23 PHP
通过实例解析PHP数据类型转换方法
2020/07/11 PHP
PHP sdk实现在线打包代码示例
2020/12/09 PHP
mouse_on_title.js
2006/08/25 Javascript
JS删除数组元素的函数介绍
2013/03/27 Javascript
jQuery获得子元素个数的方法
2015/04/14 Javascript
js 判断所选时间(或者当前时间)是否在某一时间段的实现代码
2015/09/05 Javascript
vuex实现简易计数器
2016/10/27 Javascript
jQuery.datatables.js插件用法及api实例详解
2016/10/28 Javascript
使用json-server简单完成CRUD模拟后台数据的方法
2018/07/12 Javascript
vue实现五子棋游戏
2020/05/28 Javascript
vue在图片上传的时候压缩图片
2020/11/18 Vue.js
Python检测QQ在线状态的方法
2015/05/09 Python
python django 增删改查操作 数据库Mysql
2017/07/27 Python
对numpy中布尔型数组的处理方法详解
2018/04/17 Python
python中的常量和变量代码详解
2018/07/25 Python
基于python实现简单日历
2018/07/28 Python
Python语言进阶知识点总结
2019/05/28 Python
对python tkinter窗口弹出置顶的方法详解
2019/06/14 Python
python递归下载文件夹下所有文件
2019/08/31 Python
使用turtle绘制五角星、分形树
2019/10/06 Python
使用TensorFlow搭建一个全连接神经网络教程
2020/02/06 Python
利用django model save方法对未更改的字段依然进行了保存
2020/03/28 Python
Django 解决新建表删除后无法重新创建等问题
2020/05/21 Python
锐步香港官方网上商店:Reebok香港
2020/11/05 全球购物
销售副总经理岗位职责
2013/12/11 职场文书
项目施工员岗位职责
2014/03/09 职场文书
工作说明书格式
2014/07/29 职场文书
新店开张活动方案
2014/08/24 职场文书
2016教师廉洁教育心得体会
2016/01/13 职场文书
积极心理学课程心得体会
2016/01/22 职场文书
解决Golang中ResponseWriter的一个坑
2021/04/27 Golang