php - FOSOAuthServerBundle 和 FOSUserBundle - 如何让它工作?

标签 php symfony oauth fosuserbundle fosoauthserverbundle

目前我的项目运行良好。我使用 FOSUserBundle 来管理我的用户。现在,我想实现 OAuth,所以我使用 FOSOAuthServerBundle。大多数开发人员推荐使用此 bundle 来实现 OAuth。

我遵循了 FOSOAuthServerBundle 的文档。通常,我必须在我的 security.yml 中添加更多信息,但我不知道我必须做什么......

这是我的 security.yml :

security:
    encoders:
       Symfony\Component\Security\Core\User\User: plaintext
       Moodress\Bundle\UserBundle\Entity\User: sha512

    role_hierarchy:
       ROLE_ADMIN:       ROLE_USER
       ROLE_SUPER_ADMIN: [ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

    providers:
       main:
           id: fos_user.user_provider.username

    firewalls:
        dev:
            pattern:  ^/(_(profiler|wdt)|css|images|js)/
            security: false
        oauth_token:
            pattern:    ^/oauth/v2/token
            security:   false

        oauth_authorize:
            pattern:    ^/oauth/v2/auth

        main:
            pattern: ^/
            fos_oauth:  true
            stateless:  true
            anonymous: true

我想可能有一些信息要添加到防火墙中??

我真的不知道如何使 FOSOAuthServerBundle 与 FOSUserBundle 一起工作。之前,仅使用 FOSUserBundle,我使用 FOSUserBundle 的登录表单和登录检查。现在我已经完成了 FOSOAuthServerBundle 的所有基本配置,接下来我需要做什么?我应该使用哪种形式?哪个登录检查? token 由 FOSOAuthServerBundle 自动创建?在文档中,他们展示了如何创建客户端......我应该在我的项目中添加这段代码吗?如果是……在哪里? :/

我在网上找到这篇文章:http://blog.logicexception.com/2012/04/securing-syfmony2-rest-service-wiith.html

我试图实现它,但我无法相信我们需要添加所有这些文件才能使其工作...

如果有人知道如何使用 FOSUserBundle 制作 FOSOAuthServerBundle,那将非常有帮助。

最佳答案

我刚刚安装了这个包并开始使用它。

我认为您需要先详细了解 OAuth 身份验证的工作原理。

这样您就会明白 FOSUserBundle 机制与 OAuth 并不完全相同。

您的链接是正确设置 bundle 的最佳信息。

我正在使用 MongoDB 来存储所有 4 个必需的文档:Client、AuthCode、RefreshToken 和 AccessToken

称为“创建新客户端”的步骤基本上是 FOSUserBundle 用于 OAuth 的“注册”过程。

OAuth 将使用客户端授予访问权限。

OAuth 的主要思想是保护 API,因此我建议您将配置切换为匿名:false

然后你会看到消息:

{"error":"access_denied","error_description":"需要 OAuth2 身份验证"}

当你调用你的 API 时

OAuth 的想法是获取一个访问 token 来调用您的 API。 读这个:http://blog.tankist.de/blog/2013/07/16/oauth2-explained-part-1-principles-and-terminology/

这是需要遵循 OAuth 身份验证过程的时候。

有 5 种基本方法可以使用:

const GRANT_TYPE_AUTH_CODE = 'authorization_code';
const GRANT_TYPE_IMPLICIT = 'token';
const GRANT_TYPE_USER_CREDENTIALS = 'password';
const GRANT_TYPE_CLIENT_CREDENTIALS = 'client_credentials';
const GRANT_TYPE_REFRESH_TOKEN = 'refresh_token';

要了解每一项,请查找有关 OAuth RFC 的更多文档。

它们中的每一个都对应于一个特定的调用: /oauth/v2/token?client_id=[CLIENT_ID]&response_type=code&redirect_uri=URL&grant_type=token

参见:https://github.com/FriendsOfSymfony/oauth2-php/blob/master/lib/OAuth2/OAuth2.php#L182

另请阅读此链接: blog.tankist.de/blog/2013/08/20/oauth2-explained-part-4-implementing-custom-grant-type-symfony2-fosoauthserverbundle/

“测试时间”部分解释了如何使用 OAuth。

我还在努力。

希望对您有所帮助。


此链接还指示如何使用 FOSUserBundle User 和 UserManager 可能使用密码 grant_type :如果您正在验证用户,请不要忘记设置用户提供商。

这是一个使用 FOSUserBundle 用户提供程序的示例: https://github.com/FriendsOfSymfony/FOSOAuthServerBundle/blob/master/Resources/doc/index.md

# app/config/config.yml
fos_oauth_server:
    ...

    service:
        user_provider: fos_user.user_manager

关于php - FOSOAuthServerBundle 和 FOSUserBundle - 如何让它工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21390844/

相关文章:

javascript - 如何使用 javascript 通过单击按钮淡出列表?

php - 至少包含 8 个字符和至少 1 个非字母数字字符的密码的正则表达式

symfony - 如何在 DQL 中按 NULL 排序?

php - Doctrine onFlush 事件监听器服务的 Symfony 循环引用异常

azure - "Redirect_uri is invalid"使用 Microsoft Oauth 登录不在 Microsoft 域中的帐户

javascript - Angular JS - 连接到 Woocommerce OAuth v1

php - 解析 TO header 中符合 RFC 822 的地址

PHP Web 服务器集成到本地运行的 C++ exe?他们如何互动?

symfony - 关联实体与 onDelete : CASCADE option and both soft-deleteable not working

java - Android 版 Twitter 的 oAuth 错误