gpt4 book ai didi

jQuery 在提交的数据中附加一些奇怪的字符串

转载 作者:行者123 更新时间:2023-12-03 23:01:58 25 4
gpt4 key购买 nike

重现该bug的代码(将以下代码放入html页面并读取Fiddler中提交的数据。jQuery 1.4.2工作正常,问题发生在1.5.1和1.5.2):

<html>
<head>
<script src="https://github.com/douglascrockford/JSON-js/raw/master/json2.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script>
var data = { "Name": "test??", "testDesc": "testdesc??"};
$.ajax({
url: "submit.aspx/SubmitData",
data: JSON.stringify(data),
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
cache: false
}).success(function (msg) {});
</script>
</head>
<body></body>
</html>

我使用jQuery 1.5.1进行数据处理并将数据提交到服务器

function test(name, testDesc){
var data = { "Name": name, "testDesc": testDesc};
$.ajax({
url: "submit.aspx/SubmitData",
data: JSON.stringify(data),
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
cache: false
}).success(function (msg) {//......});
}

在一千条记录中,数据中有几条记录的字符串为“jQuery151023383707909744822_1301931324827”和“jQuery151033911434971578497_1301989384660”。

这是 jQuery 的 bug 还是任何插件导致的问题?

更多信息:这个奇怪的字符串似乎取代了原来的“?”在那些记录中。例如,你喜欢StackOverflowjQuery151023383707909744822_1301931324827 我非常喜欢它。这个好么jQuery151023383707909744822_1301931324827 太棒了。

错误更新:我已经重现了该错误的案例。如果我输入“测试?”对于名称,提交的数据变为 "{"Name":"testjQuery15103933552800185728_1302170988810","Description":"fdsa"}"

最佳答案

更新:

对我来说看起来像是 jQuery 中的一个错误 这是 jQuery 中的一个错误,特别是 bug #8417大约五周前被报告错误关闭,然后重新打开,现在有一个拉取请求,修复待处理;希望 future 的版本能够修复此问题。

解决方法如下,但首先:此代码单独复制它:

jQuery(function($) {

$('#theButton').click(function go() {
var data = { "Name": "test??", "testDesc": "description"};
$.ajax({
url: "/icece5",
data: JSON.stringify(data),
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "json",
cache: false
});
});
});

Live copy

虽然我们在 jsbin.com 上看不到 POST 的结果,但我们并不关心,因为我们担心的是我们发送到服务器的结果。如果我发送该请求并在 Chrome 的开发工具中查看该请求,我会清楚地看到数据被下面描述的 JSON-P 回调名称损坏。

有趣的是,如果我们不告诉 jQuery 我们期待从服务器返回 JSON(请注意注释掉的行),则不会发生这种情况:

jQuery(function($) {

$('#theButton').click(function go() {
var data = { "Name": "test??", "testDesc": "description"};
$.ajax({
url: "/icece5",
data: JSON.stringify(data),
type: "POST",
contentType: "application/json; charset=utf-8",
//dataType: "json",
cache: false
});
});
});

Live copy

返回的数据类型不应该影响它对我们发送的数据的处理,我没想到。但它确实需要解决方法:

解决方法

var data = { "Name": "test??", "testDesc": "testdesc??"};
$.ajax({
url: "submit.aspx/SubmitData",
data: JSON.stringify(data),
type: "POST",
contentType: "application/json; charset=utf-8",
dataType: "text", // <== Tell jQuery you expect plain text
cache: false
}).success(function (data) {
data = jQuery.parseJSON(data); // <=== Then parse it yourself
});

建议在 jsFiddle.net 和 reporting it 上组合一个测试用例向 jQuery 团队求助,因为您是在现实生活中遇到问题的人。如果确实是一个错误,他们会修复它;如果没有,我很想知道为什么不...

<小时/>

原始答案:

您引用的代码正在执行 JSON 编码数据的 POST 操作,但是您提到的字符串(jQuery151023383707909744822_1301931324827 等)是 jQuery "Expando”(在运行时通过获取 jQuery 版本并向其添加随机值来确定)加上 _ 加上纪元值。 jQuery 以该形式创建字符串作为 JSON-P 回调函数的默认名称,如下所示:

jQuery-1.5.1.js 的第 1,326-1,329 行:

// Unique for each copy of jQuery on the page
// Non-digits removed to match rinlinejQuery
expando: "jQuery" + ( jQuery.fn.jquery + Math.random() ).replace( /\D/g, "" ),

和(第 7,029-7,035 行):

// Default jsonp settings
jQuery.ajaxSetup({
jsonp: "callback",
jsonpCallback: function() {
return jQuery.expando + "_" + ( jsc++ );
}
});

所以我的猜测是,您引用的代码不是生成这些值的代码,而是您有其他代码使用它们。

如果您使用 JSON-P 进行请求,则 JSON-P 回调的名称将替换请求 URL 中的 ?。我不希望它在您的数据中执行此操作。

我会检查您对 ajaxSettings 等的使用。如果您切换到未缩小的版本进行调试,您还可以在您使用的任何调试器中设置一个断点(并且您使用一个,对吗?there's no excuse not to)在第 7,033 行(这些字符串是正在创建),然后找出代码的哪一部分触发了它。

关于jQuery 在提交的数据中附加一些奇怪的字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5578754/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com