AJAX post 请求 returns 不同请求的相同响应
AJAX post request returns same response for different requests
在使用 paypal 结账时,我遇到了问题,后来即使是两个不同的用户,也会导致相同的付款。
它发生在创建支付流程中。
我的贝宝结账设置:
$.ajaxSetup({ cache: false });
paypal.Button.render({
env: 'production',
locale: 'en_US',
style: {
color: 'silver',
size: 'medium',
label: 'checkout',
shape: 'rect',
layout: 'vertical',
},
payment: (data, actions) => {
return new Promise((resolve, reject) => {
$.ajax({
url: '/p/create-payment/',
dataType: 'json',
data: {
body: body
},
method: 'POST',
headers: { 'X-CSRF-Token': '{{csrfToken}}' }
})
.done(( data ) => {
resolve(data.id)
reject("")
})
})
},
onAuthorize: (data, actions) => {
return new Promise((resolve, reject) => {
$.ajax({
url: '/p/execute-payment/',
dataType: 'json',
data: {
paymentID: data.paymentID,
payerID: data.payerID,
body: body,
},
method: 'POST',
headers: { 'X-CSRF-Token': '{{csrfToken}}' }
})
.done(( data ) => {
if(data.status === 'success') {
resolve(window.open('success',"_self"))
}else if(data.status === 'pending'){
resolve(window.open('pending, "_self"))
} else reject(window.open('failure', "_self"))
})
})
},
onError: (err) => {
window.open('paymentFailure', "_self");
console.error(err)
}
}, '#paypal-button');
第一次尝试:
我转到我的页面并打开 paypal 结账,应该接收付款的人是正确的,金额和其他一切,请求本身需要大约 3-4 秒
第二次尝试:
第二次打开页面时,我点击结帐按钮,这次请求需要 0.2-0.4 秒,数据与第一次创建的付款完全相同,甚至来自 paypal 的 PAY-ID 也是相同的
我可以记录从 ajax 请求返回的数据到 /p/create-payment 第一次创建付款工作正常如上所述,但第二次我看到与第一次完全相同的数据.
我想指出,我的服务器上有日志,它们在第二次付款创建过程中没有显示,就好像它没有请求并且立即完成一样.
请求截图如下:
我也一直在尝试清除 cache/cookies 浏览器,但这并不能解决问题。用户可以在两个不同的设备上,这个问题仍然会发生
res.header("Cache-Control", "no-cache, no-store, must-revalidate")
res.header("Pragma", "no-cache")
res.header("Expires", "0")
服务器正在缓存数据,因此取消缓存是解决方案。
在使用 paypal 结账时,我遇到了问题,后来即使是两个不同的用户,也会导致相同的付款。
它发生在创建支付流程中。
我的贝宝结账设置:
$.ajaxSetup({ cache: false });
paypal.Button.render({
env: 'production',
locale: 'en_US',
style: {
color: 'silver',
size: 'medium',
label: 'checkout',
shape: 'rect',
layout: 'vertical',
},
payment: (data, actions) => {
return new Promise((resolve, reject) => {
$.ajax({
url: '/p/create-payment/',
dataType: 'json',
data: {
body: body
},
method: 'POST',
headers: { 'X-CSRF-Token': '{{csrfToken}}' }
})
.done(( data ) => {
resolve(data.id)
reject("")
})
})
},
onAuthorize: (data, actions) => {
return new Promise((resolve, reject) => {
$.ajax({
url: '/p/execute-payment/',
dataType: 'json',
data: {
paymentID: data.paymentID,
payerID: data.payerID,
body: body,
},
method: 'POST',
headers: { 'X-CSRF-Token': '{{csrfToken}}' }
})
.done(( data ) => {
if(data.status === 'success') {
resolve(window.open('success',"_self"))
}else if(data.status === 'pending'){
resolve(window.open('pending, "_self"))
} else reject(window.open('failure', "_self"))
})
})
},
onError: (err) => {
window.open('paymentFailure', "_self");
console.error(err)
}
}, '#paypal-button');
第一次尝试: 我转到我的页面并打开 paypal 结账,应该接收付款的人是正确的,金额和其他一切,请求本身需要大约 3-4 秒
第二次尝试: 第二次打开页面时,我点击结帐按钮,这次请求需要 0.2-0.4 秒,数据与第一次创建的付款完全相同,甚至来自 paypal 的 PAY-ID 也是相同的
我可以记录从 ajax 请求返回的数据到 /p/create-payment 第一次创建付款工作正常如上所述,但第二次我看到与第一次完全相同的数据.
我想指出,我的服务器上有日志,它们在第二次付款创建过程中没有显示,就好像它没有请求并且立即完成一样.
请求截图如下:
我也一直在尝试清除 cache/cookies 浏览器,但这并不能解决问题。用户可以在两个不同的设备上,这个问题仍然会发生
res.header("Cache-Control", "no-cache, no-store, must-revalidate")
res.header("Pragma", "no-cache")
res.header("Expires", "0")
服务器正在缓存数据,因此取消缓存是解决方案。