我正在使用 Slim PHP 并希望將用戶重定向到/login如果他們未登錄但嘗試訪問需要用戶登錄的頁面。在搜索如何構建我的中間件時,我發現此代碼的所有變體在那個地方class Auth{ public function requireLogin(Request $request, Response $response, $next){ if( !isLoggedIn() ) return $response->withRedirect('/login', 403); return $next($request, $response); } }例如在這個 SO 答案和這個 Slim discourse answer中。問題是我無法將重定向和 HTTP 403 結合使用。據我所知,正常的 HTTP 重定向僅限于HTTP 代碼 3xx。實際上,上面的代碼在與 example 一起使用時可以正常工作302。我是否遺漏了某些東西,或者所有答案都結合起來withRedirect并且403“不正確”(因為不會導致用戶瀏覽器的實際重定向)?
1 回答

浮云間
TA貢獻1829條經驗 獲得超4個贊
如果您的應用程序是使用 Web 瀏覽器訪問的 HTML 網站,則瀏覽器僅在狀態碼為 1 時才會重定向3xx
。
如果您的應用程序是使用 HTTP 客戶端訪問的 API,那么您有更多的余地。對于 API,您可以使用403
或401
狀態代碼來指示未經授權無法完成請求。您還可以包含一個Location
標頭來告訴客戶去哪里獲得授權,但當然,如果他們跟進該鏈接,則取決于客戶。
- 1 回答
- 0 關注
- 183 瀏覽
添加回答
舉報
0/150
提交
取消