이전 프로젝트에서는 유효성 검사가 실패했을 때 POST 요청에서 직접 뷰를 반환하는 것이 최선의 접근 방식이 아니었습니다.
사용자가 잘못된 데이터가 포함된 로그인 양식을 제출하면 양식에 오류 메시지가 표시되고 사용자가 로그인 페이지로 리디렉션됩니다. 그러나 사용자가 페이지를 새로 고치거나 다른 곳으로 이동했다가 로그인 페이지로 돌아가면 동일한 오류 메시지가 지속됩니다.
이 문제를 해결하기 위해 세션을 사용하여 오류를 저장하고 PRG 패턴을 구현할 수 있습니다. $_SESSION 슈퍼전역 변수에 오류를 저장하고 create.php의 오류 문을 다음과 같이 업데이트할 수 있습니다:
$_SESSION['errors'] = $form->errors(); view('session/create.view.php', [ 'errors' => $_SESSION['errors'] ?? [] ]);?? [] ]);
그러나 이러한 변경에도 불구하고 문제는 여전히 지속됩니다. 이 문제를 해결하려면 return 문을 다음과 같이 변경해야 합니다.
return redirect ('/login');return 리디렉션('/login');
엘
오류가 발생한 경우 사용자를 로그인 페이지로 이동하지만 사용자 w
에게는 오류를 표시하지 않습니다.
그런 다음 $_SESSION 슈퍼전역 변수를 플래시하여 잠시 후 세션을 삭제합니다.
return redirect ('/login');$_SESSION['_flashed']['errors'] = $form->errors();
이제 문제가 해결되었음을 알 수 있지만 이 코드를 리팩토링하려면 클래스에 PRG 메서드를 추가해야 합니다.
리팩토링을 위해 사용자 세션을 관리하는 세션 클래스가 포함된 Core/Session.php라는 새 파일을 생성합니다.
return redirect ('/login');
이 세션 클래스를 사용하면 PRG 패턴과 세션 플래싱을 구현하여 사용자 세션을 관리하고 중복 양식 제출과 원치 않는 오류 메시지 지속을 방지할 수 있습니다.
이 파일에서 has 메소드는 세션에 키가 존재하는지 여부를 나타내는 부울 값을 반환합니다.
return redirect ('/login');. 공개 정적 함수 has($key) { return (bool) static::get($key); }
function.php 파일에서 세션 클래스를 사용하도록 로그아웃 함수를 리팩토링합니다.
return redirect ('/login');세션::destroy();
프로젝트가 이미 잘 진행되고 있기 때문입니다. 하지만 코드를 단일 명령문으로 통합하려면 Core/Session.php에서 get 메소드를 리팩토링해야 합니다.
return redirect ('/login');공용 정적 함수 get($key, $default = null) { $_SESSION['_flash'][$key] 반환 ?? $_SESSION[$key] ?? $기본; }
오늘 프로젝트에서는 코드의 모양을 개선하고 이해하기 쉽게 만들고 성능을 높이기 위해 많은 리팩토링이 수행되었습니다.
명확히 이해하셨기를 바랍니다!.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3