仆人键模式 Valet Key Pattern

未匹配的标注

描述

    使用一个令牌或密钥,向客户提供受限制的资源或服务。这个模式可以最大限度地降低成本,最大限度地提高可扩展性和性能。

背景和问题

    客户端和网络浏览器经常需要读写文件或者数据流,这些操作都要占用计算机资源,CPU,存储,宽带等等。数据的上传和下载一般都要求客户端拥有访问的安全凭证的。

解决方案

    向客户端提供令牌,这个令牌通常被称为仆人键。用于安全认证,对资源有时间限制的访问,限制特定的操作, 控制数据传输的速度等等。

liaoliaophp 仆人键模式

注意事项

  1. 管理密钥的有效性状态和时间。
  2. 要精确地指定资源到关键应用。
  3. 考虑如何控制用户的行为。
  4. 验证和过滤所有上传的数据。
  5. 审核所有操作。
  6. 提供关键安全。
  7. 在传输过程中保护敏感数据。
  8. 保证令牌权限策略的灵活性。
  9. 确保令牌服务,客户端,服务端的时间一致,或者令牌服务的时间比其他的要早一点。
  10. 包含密钥的URL将被记录在服务器日志文件中。如果日志数据发送到监控系统或存储在另一位置中,需要考虑的延迟,以防止密钥的泄漏,直至经过其有效期限已经过期。
  11. 考虑跨域对令牌的影响。

何时使用

验证和限制应用之间的资源传输。

结构中包含的角色

  1. User 用户
  2. Application 令牌应用
  3. TargetResource 目标资源

最小可表达代码

// 令牌应用
class Application
{
    protected $tokens = [
        'aaa', 'bbb', 'ccc',
    ];

    public function getToken()
    {
        return $this->tokens[0];
    }

    public function verify($token)
    {
        return in_array($token, $this->tokens);
    }
}

// 用户
class User
{
    public function accessResource()
    {
        $token = (new Application)->getToken();

        (new TargetResource)->debug($token);
    }
}

// 目标资源
class TargetResource
{
    public function debug($token)
    {
        $result = (new Application)->verify($token);
        if ($result) {
            var_dump('我是资源');
        } else {
            var_dump('没有权限');
        }
    }
}

(new User)->accessResource();

本文章首发在 LearnKu.com 网站上。

上一篇 下一篇
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 0
发起讨论 只看当前版本


暂无话题~