簡體   English   中英

Symfony2:如何實現自定義用戶登錄和注冊 - 擺脫FOSUSerBundle

[英]Symfony2: how to implement custom user login & registration - get rid of FOSUSerBundle

我正試圖擺脫FOSUserBundle,因為我想實現一個與我的用戶建立多種關系的角色實體。

所以我的問題是:是否會有一步一步的教程來替換這個FOSUserBundle? 如果沒有,有人可以至少通過我需要實施的元素來指導我,因為我覺得我總是忘記了一些事情。

到目前為止,我有:

  1. 類User實現AdvancedUserInterface,\\ Serializable
  2. UserProvider類實現UserProviderInterface
  3. 具有公共函數registerAction(Request $ request)的控制器,用於處理將用戶保存在數據庫中。

在這里,我可以保存用戶,我看到鹽,密碼,用戶名和電子郵件都已保存,但在處理完請求后,我什么也得不到,登錄是不可能的。

我是否還需要實施:

  1. 自定義驗證提供程序
  2. 或用戶API密鑰

如果是的話,哪一個?

接下來呢?

我的注冊碼:為什么沒有調用return語句?

/**
 * @Route("/register_user", name="register_user")
 * @Method({"GET","POST"})
 * @param Request $request
 * @param bool $extendLayout
 * @return null|\Symfony\Component\HttpFoundation\RedirectResponse|\Symfony\Component\HttpFoundation\Response
 */
public function registerAction(Request $request, $extendLayout=true)
{
    $formManager = $this->get('form_manager');
    $user = new User();
    $user->setEnabled(true);

    $form = $formManager->createForm(new UserRegistrationType(), $user, 'POST', 'register_user',null, false);

    if ($request->getMethod() == 'POST')
    {
        if ($formManager->handleRequestAndValidate($form))
        {

            $userSecurityManager = $this->get('user_security_manager');
            $userSecurityManager->updateUser($user, true);

            //This return won't get called, is there an eventlistener on the register event ?
            return $this->redirect($this->generateUrl('registration_confirmed'));

        }
    }

    $layout = $extendLayout == true ? 'User/Registration/register.html.twig' : 'User/Registration/register_content.html.twig';

    return $this->render($layout, array(
            'form' => $form->createView(),
        ));
}

我的登錄表單被發送到login_check路由,我相信symfony正在處理這個路由,並且我正在創建的用戶登錄失敗。 為什么?

我的登錄表格:

<div class="fmu_panel fmu_login">

    <h3>Vous êtes inscrit</h3>

    <div class="panel-content">
        <form action="{{ path("login_check") }}" id="signup-form_id" method="post">
            <input type="hidden" name="_csrf_token" value="{{ csrf_token }}" />

            {% if error %}
                <div class="form-group">
                <div class="alert alert-danger" role="alert">
                    {#{{ error.messageKey|trans(error.messageData, 'security') }}#}
                    Mot de passe ou nom d'utilisateur incorrect.
                </div>
                </div>
            {% endif %}

            <div class="form-group w-icon">
                <input type="text" id="username" name="_username" value="{{ last_username }}" required="required" class="form-control" placeholder="E-mail ou pseudo" />
                <i class="fa fa-user"></i>
            </div> <!-- / Username -->

            <div class="form-group w-icon">
                <input type="password" id="password" name="_password" required="required" class="form-control" placeholder="Mot de passe"  />
                <i class="fa fa-lock"></i>
            </div> <!-- / Password -->

            <div class="form-group">
                <label for="_remember_me" class="checkbox-inline">
                    <input type="checkbox" name="_remember_me" id="remember_me" checked>
                    Se souvenir de moi
                </label>
            </div>

            <div class="form-actions">
                <input type="submit" value="S'identifier" class="btn btn-primary" name="_submit" id="fmu_signin">
                <a href="#" class="forgot-password btn btn-danger pull-right" id="fmu_forgot_password_link">Mot de passe oublié ?</a>
            </div>

{#
            <div class="social">
                <a href="{{ path('hwi') }}twitter" class="btn btn-default">Se connecter avec <span>Facebook</span></a>
            </div>
#}

        </form>

        <div id="fmu_password_reset">

            {{ render(controller('AppBundle:User/UserSecurity:requestNewPassword')) }}

        </div>
    </div>
</div>



<script>

// Show/Hide password reset form on click

$(function(){
    $('#fmu_forgot_password_link').on('click', function (e) {
        e.preventDefault();
        $('#fmu_password_reset').fadeIn(400);
        $('#signup-form_id').fadeOut(400);
    });
    $('#fmu_password_reset .close').click(function (e) {
        e.preventDefault();
        $('#fmu_password_reset').fadeOut(400);
        $('#signup-form_id').fadeIn(400);
    });

});
</script>

您可以按照教程: 如何從數據庫加載安全用戶


基本上你需要:

  • 自定義用戶類( 你有
  • 配置Symfony Security組件( 可能缺少
  • 可選 )自定義用戶提供程序

這是上面提到的教程中的security.yml示例:

# app/config/security.yml
security:
    encoders:
        AppBundle\Entity\User:
            algorithm: bcrypt

    # ...

    providers:
        our_db_provider:
            entity:
                class: AppBundle:User
                property: username
                # if you're using multiple entity managers
                # manager_name: customer

    firewalls:
        default:
            pattern:    ^/
            http_basic: ~
            provider: our_db_provider

    # ...

您的登錄表單似乎是正確的,因此它應該使用正確的安全配置。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM