[英]Symfony2 FOSUserBundle - simple way to get rid of the email fields in user
[英]Symfony2: how to implement custom user login & registration - get rid of FOSUSerBundle
我正試圖擺脫FOSUserBundle,因為我想實現一個與我的用戶建立多種關系的角色實體。
所以我的問題是:是否會有一步一步的教程來替換這個FOSUserBundle? 如果沒有,有人可以至少通過我需要實施的元素來指導我,因為我覺得我總是忘記了一些事情。
到目前為止,我有:
在這里,我可以保存用戶,我看到鹽,密碼,用戶名和電子郵件都已保存,但在處理完請求后,我什么也得不到,登錄是不可能的。
我是否還需要實施:
如果是的話,哪一個?
接下來呢?
我的注冊碼:為什么沒有調用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>
您可以按照教程: 如何從數據庫加載安全用戶 。
基本上你需要:
這是上面提到的教程中的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.