亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Golang - 服務器端登錄處理 - 登錄后如何恢復請求?

Golang - 服務器端登錄處理 - 登錄后如何恢復請求?

Go
慕田峪7331174 2022-10-17 19:24:21
目前,我正在使用 Gin 框架開發一個具有服務器端渲染的 Web 應用程序,但我遇到了登錄攔截問題。當 HTTP GET 請求到達端點時,中間件用于檢查瀏覽器 cookie 并將流量重定向到登錄頁面。這工作正常,成功登錄后,用戶總是被重定向到儀表板頁面。我的問題是我應該如何將用戶重定向回最初請求的 URI 而不是儀表板頁面?此外,在 HTTP POST 上還有一個更復雜的場景。看起來 HTTP POST 方法不適用于重定向。另外,在用戶成功登錄后,我將如何使用相同的 post 請求恢復請求?謝謝您的幫助!
查看完整描述

1 回答

?
慕田峪9158850

TA貢獻1794條經驗 獲得超8個贊

對于 HTTP GET 場景,這很簡單,您需要在某處記住原始 URL。您可以通過以下幾種方式來解決此問題:

  1. 將 URL 存儲在會話信息中(如果有,您確實需要未經過身份驗證的用戶的會話)

  2. 將其存儲在查詢字符串中,例如,重定向到example.com/login?original=https%3A%2F%2Fexample.com%2Fanother-page. 您的登錄頁面可以查找查詢參數并將其包含在登錄表單中,或者確保登錄表單的操作與給定的 URI 匹配。在成功的登錄嘗試中,您可以從查詢參數中獲取原始 URL 并將其設置為Location.

  3. 將原始 URL 存儲在 cookie 中,成功登錄后,您只需檢查 cookie 值并使用它。


至于 HTTP POST 場景。如果您只想將相同的 POST 請求重定向到不同的 URL,您可以使用307 臨時重定向。307 將保留請求正文和方法,而不是將其轉換為 GET 請求,如303 See Other302 Found。

在顯示登錄屏幕和成功登錄后恢復原始 POST 有點復雜。當您重定向到登錄頁面時,您會中斷用戶的流程,也許最好讓用戶在登錄后重新發布他們的請求,而不是為他們做這件事。

話雖如此,這在技術上是可行的。我們需要兩個步驟,首先是存儲所有數據以重新創建請求。然后在登錄完成后,我們可以使用保存的數據呈現一個表單并使用 javascript 提交表單。通過添加:

<script>document.getElementById("myForm").submit();</script>

在您的表單之后,瀏覽器將在加載 javascript 后提交表單,從而重新創建原始 POST。

存儲部分可以通過服務器端會話或 cookie 完成。


查看完整回答
反對 回復 2022-10-17
  • 1 回答
  • 0 關注
  • 154 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號