gpt4 book ai didi

javascript - Firebase云函数返回304错误然后重启

转载 作者:数据小太阳 更新时间:2023-10-29 04:48:47 24 4
gpt4 key购买 nike

几个月来我一直坚持这个。我从函数中删除了一些次要细节,但没有什么大不了的。我有这个 https 云函数,可以结束 session ,然后使用 endTimestartTime 计算 bill,然后将其返回给客户端。

startTime 从实时 firebase 数据库( session 启动函数放在那里)中获取。

我的代码片段:

exports.endSession = functions.https.onRequest(async (req, res) => {
console.log("endSession() called.")
if(req.method == 'GET'){
bid = req.query.bid
session_cost = req.query.sessioncost
}else{
bid = req.body.bid
session_cost = req.body.sessioncost
}

start_time_ref = admin.database().ref("/online_sessions/").child(bid).child("start_time")
start_time_snapshot = await start_time_ref.once('value')

console.log("start_time_snapshot: "+start_time_snapshot.val())

start_time_snapshot = moment(start_time_snapshot.val(), 'dddd MMMM Do YYYY HH:mm:ss Z');
endDateTime = getDateTime()

console.log("startTime: " + start_time_snapshot.toString())
console.log("endTime: " + endDateTime.toString())
hour_difference = getHourDifference(start_time_snapshot, endDateTime)

bill = ride_cost * Math.ceil(hour_difference)
console.log("bill: "+bill)

var s_phone
sSessionlinks_ref = admin.database().ref('/sSessionlinks/')
sSessionlinks_snapshot = await sSessionlinks_ref.once('value')

sSessionlinks_snapshot.forEach((sid)=>{
if(sid.val() == bid){
s_phone = sid.key
}
})

s_fcm_token_ref = admin.database().ref("/s/").child(s_phone).child("FCM")
s_fcm_token_snapshot = await s_fcm_token_ref.once('value')

try{ // telling another client that session has ended.
await admin.messaging().send({
data: {
type: "sessionCompleted",
bill: bill.toString()
},
token: s_fcm_token_snapshot.val()
})
}catch(error){

}

//deleting this session from online sessions
online_session_ref = admin.database().ref('/online_sessions/').child(bid)
await online_session_ref.remove()

//puting this session as available
available_session_ref = admin.database().ref('/available_sessions/')
json = {}
json[bid] = s_phone
await available_session_ref.update(json) // session made available


res.status(200).send(bill.toString())
// here it *sometimes* returns 304 and then restarts but since i've already removed online_session_ref I cannot get startTime again because its removed with online_sessions so it fails.
// return
})

第一次调用时。它正确地进行了所有计算,但以 304 响应。因此(我认为客户端)重新发送请求并再次调用该函数,但由于 session 已被破坏,因此它无法计算 startTime

为什么当它第一次被调用时,即使所有的计算都正确发生,它返回的是 304 而不是 200?这个问题不会一直发生。通常在很长时间后调用此函数时会发生这种情况,但我不确定。我不知道是什么原因造成的。

我用过的辅助函数:

function getHourDifference(s, e){
return moment.duration(e.diff(s)).asHours()
}


function getDateTime(){
d = moment.utc().utcOffset('+0530')
return d
}

当函数第一次结束时,文本有效载荷是函数执行耗时 794 毫秒,完成状态代码 304

当它第二次运行时(它无法获取 startTime 因为它在第一次运行时被删除了。首先不应该有第二次运行。),有效负载文本是 函数执行耗时 234 毫秒,完成时状态代码为 200(它是 200,但返回 NaN,因为它不能在没有 startTime 的情况下进行计算。

编辑:正如你们中的一些人要求我说明函数是如何被调用的:

它是使用 Volley 从 Android 应用程序调用的。确保参数不为空。调用该函数的代码段是:

    // Setting the button's listeners.
endSessionButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

progressDialog = new SweetAlertDialog(getContext(), SweetAlertDialog.PROGRESS_TYPE);
progressDialog.getProgressHelper().setBarColor(Color.parseColor("#A5DC86"));
progressDialog.setTitleText("Ending session...");

AlertDialog endDialog = new AlertDialog.Builder(getContext()).create();
endDialog.setTitle("End Session?");

Log.e("sessioncost", String.valueOf(session_cost));

endDialog.setButton(Dialog.BUTTON_POSITIVE, "Yes", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
progressDialog.show();
// Instantiate the RequestQueue.
RequestQueue queue = Volley.newRequestQueue(getContext());

String url = "https://us-central1-something-something.cloudfunctions.net/endSession?bid=" + bid + "&sessioncost=" + session_cost;
Log.e("end sesion button", url);
// Request a string response from the provided URL.
StringRequest endSessionRequest = new StringRequest(Request.Method.GET, url,
new Response.Listener<String>() {
@Override
public void onResponse(final String response) {
progressDialog.dismiss();
Toast.makeText(getContext(), "Session Completed", Toast.LENGTH_LONG).show();

progressDialog = new SweetAlertDialog(getContext(), SweetAlertDialog.SUCCESS_TYPE);
progressDialog.getProgressHelper().setBarColor(Color.parseColor("#A5DC86"));
progressDialog.setTitleText("Session Completed: Bill");
progressDialog.setContentText("Please pay ?" + response + " to s.");
progressDialog.setCancelable(false);
progressDialog.show();

changeState('1');

bill_in_paise = Float.parseFloat(response) * 100;
Log.e("bill", bill_in_paise.toString());
progressDialog.setConfirmClickListener(new SweetAlertDialog.OnSweetClickListener() {
@Override
public void onClick(SweetAlertDialog sweetAlertDialog) {

sweetAlertDialog.dismiss();
Intent intent = new Intent(getContext(), PaymentActivity.class);
intent.putExtra("amt", bill_in_paise.toString());
startActivityForResult(intent, REQUEST_CODE);
}
});


}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(getContext(), error.toString(), Toast.LENGTH_LONG).show();
}// onErrorResnponse - END
});

// Add the request to the RequestQueue. Cuz volley is asyc af.
queue.add(endSessionRequest);
// VOLLEY REQUEST - END
}
});
endDialog.setButton(Dialog.BUTTON_NEGATIVE, "No", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Toast.makeText(getContext(), "Session not cancelled. " + which, Toast.LENGTH_LONG).show();
}
});

endDialog.show();


}

}
}); // endSessionButton onclick - end

更新:@tuledev 通过变通方法帮助修复了 304,但问题仍然存在。即使状态代码为 200,云函数也会以某种方式再次调用,我收到了 NaN 账单。目前我不知道是什么原因造成的。

最佳答案

304状态是因为响应和前面一样。 Firebase 云响应 304,客户端将获取缓存数据。

为了防止304状态,我们可以返回账单的值+uid,或者让响应与之前的不同。

正如 OP 和我讨论的那样,304 已解决,但问题仍然存在。所以我认为问题出在客户端。

希望有人能帮助他。

编辑:OP 在这里,我将客户端代码更改为使用 okhttp 而不是 volley,经过 2 天的测试,一切似乎都很好。 Tuledev 的回答确实修复了 304 但即使在 200 之后问题仍然存在。只需使用 okhttp 而不是 volley。

关于javascript - Firebase云函数返回304错误然后重启,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55068764/

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