使用 PRG 模式和闪烁进行会话处理

WBOY
发布: 2024-07-18 21:46:21
原创
365 人浏览过

Session Handling with the PRG pattern and Flashing

在我们之前的项目中,验证失败时直接从 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 方法

会话类(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']);
    }
}
登录后复制
  1. flash 方法将数据存储在 $_SESSION['_flash'] 数组中,用于会话刷新。
  2. get 方法检查 $_SESSION['_flash'] 中是否有 flash 数据并返回。如果没有,则返回常规会话数据或默认值。
  3. unflash 方法会取消设置闪烁的数据,使其仅可用于下一个请求。
  4. PRG 模式的实现方式是使用 put 方法在会话中存储数据,重定向(例如,使用 return redirect('/login');),然后使用 get 方法在下一个请求中检索数据。

通过使用这个 Session 类,我们可以实现 PRG 模式和会话闪烁来管理用户会话并防止重复的表单提交和不需要的错误消息持久化。

有方法

在此文件中,has 方法返回一个布尔值,指示会话中是否存在某个键:

. 

public static function has($key) {
    return (bool) static::get($key);
}
登录后复制

重构注销功能

在function.php文件中,我们重构注销函数以使用Session类:

Session::destroy();
登录后复制

重构 get 方法

由于该项目已经运行良好。但是我们需要重构 Core/Session.php 中的 get 方法,将代码合并到单个语句中:

public static function get($key, $default = null) {
    return $_SESSION['_flash'][$key] ?? $_SESSION[$key] ?? $default;
}
登录后复制

我们今天的项目进行了大量重构,使其外观更好,易于理解并提高代码的性能。

希望您已经清楚地理解了!.

以上是使用 PRG 模式和闪烁进行会话处理的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!