1 回答

TA貢獻1794條經驗 獲得超8個贊
對于 HTTP GET 場景,這很簡單,您需要在某處記住原始 URL。您可以通過以下幾種方式來解決此問題:
將 URL 存儲在會話信息中(如果有,您確實需要未經過身份驗證的用戶的會話)
將其存儲在查詢字符串中,例如,重定向到
example.com/login?original=https%3A%2F%2Fexample.com%2Fanother-page
. 您的登錄頁面可以查找查詢參數并將其包含在登錄表單中,或者確保登錄表單的操作與給定的 URI 匹配。在成功的登錄嘗試中,您可以從查詢參數中獲取原始 URL 并將其設置為Location
.將原始 URL 存儲在 cookie 中,成功登錄后,您只需檢查 cookie 值并使用它。
至于 HTTP POST 場景。如果您只想將相同的 POST 請求重定向到不同的 URL,您可以使用307 臨時重定向。307 將保留請求正文和方法,而不是將其轉換為 GET 請求,如303 See Other或302 Found。
在顯示登錄屏幕和成功登錄后恢復原始 POST 有點復雜。當您重定向到登錄頁面時,您會中斷用戶的流程,也許最好讓用戶在登錄后重新發布他們的請求,而不是為他們做這件事。
話雖如此,這在技術上是可行的。我們需要兩個步驟,首先是存儲所有數據以重新創建請求。然后在登錄完成后,我們可以使用保存的數據呈現一個表單并使用 javascript 提交表單。通過添加:
<script>document.getElementById("myForm").submit();</script>
在您的表單之后,瀏覽器將在加載 javascript 后提交表單,從而重新創建原始 POST。
存儲部分可以通過服務器端會話或 cookie 完成。
- 1 回答
- 0 關注
- 154 瀏覽
添加回答
舉報