在我们之前的项目中,验证失败时直接从 POST 请求返回视图并不是最好的方法。
当用户提交包含无效数据的登录表单时,表单会显示错误消息并将用户重定向到登录页面。但是,如果用户刷新页面或导航离开并返回到登录页面,相同的错误消息仍然存在。
为了解决这个问题,我们可以使用会话来存储错误并实现 PRG 模式。我们可以将错误存储在 $_SESSION 超全局变量中,并将 create.php 中的错误语句更新为:
$_SESSION['errors'] = $form->errors(); view('session/create.view.php', [ 'errors' => $_SESSION['errors'] ?? [] ]);
但即使做出了这样的改变,问题仍然存在。为了解决这个问题,我们必须将 return 语句更改为:
return redirect ('/login');
我
如果发生任何错误,它会将用户移至登录页面,但不会向用户 w
显示错误
然后我们刷新 $_SESSION 超全局变量以在短时间内销毁会话:
$_SESSION['_flashed']['errors'] = $form->errors();
现在您可以注意到问题已解决,但要重构此代码,我们必须在类中添加 PRG 方法
为了重构,我们创建一个名为 Core/Session.php 的新文件,其中包含管理用户会话的 Session 类:
<?php namespace Core; class Session { public static function has($key) { return (bool) static::get($key); } public static function put($key, $value) { $_SESSION[$key] = $value; } public static function get($key, $default = null) { return $_SESSION['_flash'][$key] ?? $_SESSION[$key] ?? $default; } public static function flash($key, $value) { $_SESSION['_flash'][$key] = $value; } public static function unflash() { unset($_SESSION['_flash']); } public static function flush() { $_SESSION = []; } public static function destroy() { static::flush(); session_destroy(); $params = session_get_cookie_params(); setcookie('PHPSESSID', '', time() - 3600, $params['path'], $params['domain'], $params['secure'], $params['httponly']); } }
通过使用这个 Session 类,我们可以实现 PRG 模式和会话闪烁来管理用户会话并防止重复的表单提交和不需要的错误消息持久化。
在此文件中,has 方法返回一个布尔值,指示会话中是否存在某个键:
. public static function has($key) { return (bool) static::get($key); }
在function.php文件中,我们重构注销函数以使用Session类:
Session::destroy();
由于该项目已经运行良好。但是我们需要重构 Core/Session.php 中的 get 方法,将代码合并到单个语句中:
public static function get($key, $default = null) { return $_SESSION['_flash'][$key] ?? $_SESSION[$key] ?? $default; }
我们今天的项目进行了大量重构,使其外观更好,易于理解并提高代码的性能。
希望您已经清楚地理解了!.
以上是使用 PRG 模式和闪烁进行会话处理的详细内容。更多信息请关注PHP中文网其他相关文章!