로그인 후 이전 페이지로 리디렉션
웹사이트에 로그인할 때 사용자가 보고 있던 페이지로 다시 리디렉션되는 것이 편리한 경우가 많습니다. 이 질문은 사용자가 의도한 페이지 대신 index.php로 리디렉션되는 코드 문제를 탐구합니다.
제공된 샘플 코드에서 login-check.php 스크립트는 로그인 상태를 확인하고 매개변수(p)를 login.php 페이지로 리디렉션합니다. 그러나 사용자를 원하는 페이지로 보내는 대신 index.php로 리디렉션합니다.
이 문제를 해결하기 위해 다음 솔루션이 제안됩니다.
-
사용자의 현재 페이지를 쿼리 문자열로 전달:
- 사용자의 현재 페이지를 저장하는 숨겨진 입력 필드를 포함하도록 로그인 양식을 수정하세요. login.php 스크립트에 $_SERVER['REQUEST_URI']를 전달하면 됩니다.
- 예를 들어, 사용자가 기사(comment.php?articleid=17)를 읽고 있다가 나가려고 하면 댓글이 있는 경우 URL은 다음과 같이 수정됩니다.
login.php?location=comment.php?articleid=17
-
"위치" 쿼리 문자열 처리 login-check.php:
- login-check.php 스크립트에서 $_POST['location']이 채워져 있는지 확인하세요. 그렇다면 $redirect 변수에 저장하세요.
-
로그인 상태 및 위치에 따른 리디렉션:
- 로그인에 성공했다면 $redirect에 리다이렉트 URL이 있는지 확인해보세요. 그렇다면 사용자를 해당 페이지로 리디렉션하세요. 그렇지 않으면 index.php로 리디렉션하세요.
- 로그인에 실패하거나 사용자가 이미 로그인한 경우 적절한 오류 메시지를 처리하거나 필요에 따라 리디렉션하세요.
-
리디렉션 URL 검증:
사용자를 리디렉션하기 전에 $_GET['location'] 값을 검증하여 사용자가 악성 URL에 액세스하려고 시도하지 않는지 확인하는 것이 중요합니다.
-
인코딩 쿼리 문자열:
특수 문자를 올바르게 인코딩하려면 URL을 $_GET 매개변수로 전달할 때 urlencode를 사용하세요.
이러한 변경 사항을 구현하면 사용자가 이전에 보고 있던 페이지로 성공적으로 리디렉션됩니다. 로그인 후 원활한 사용자 경험을 보장합니다.
위 내용은 로그인한 후 이전 페이지 대신 index.php로 리디렉션되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!