gpt4 book ai didi

symfony1 - Symfony sfDoctrineGuardPlugin 自定义登录查询

转载 作者:行者123 更新时间:2023-12-03 06:23:29 26 4
gpt4 key购买 nike

我使用 symfony sfDoctrineGuardPlugin 来管理前端用户和后端用户的身份验证。没关系,只是我不希望前端用户能够登录后端应用程序。我可以设置凭据,但在用户通过身份验证后会检查凭据。我想要的是以表单形式登录,永远不会验证不在后端组中的用户。我怎样才能做到这一点?

最佳答案

我想我找到了更好的解决方案。 sfDoctrineGuard 插件有自己的后验证器,用于检查用户检索的可选可调用对象。

//app.yml
all:
sf_guard_plugin:
retrieve_by_username_callable: sfGuardUser::getForBackend

//sfGuardUser.class.php

public static function getForBackend($username)
{
$query = Doctrine::getTable('sfGuardUser')->createQuery('u')
->leftJoin('u.Groups g')
->leftJoin('g.Permissions p')
->where('u.username = ? OR u.email_address = ?', array($username, $username))
->addWhere('u.is_active = ?', true)
->addWhere('p.name = ?', 'backend');

return $query->fetchOne();
}

关于symfony1 - Symfony sfDoctrineGuardPlugin 自定义登录查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4735422/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com