如何扩展/定制MVC4互联网应用程序的WebSecurity/SimpleMembership

3

我一直在尽力寻找更多有关如何修改/扩展/定制MVC4 Internet Application(EF 5 Code First)中默认会员系统的信息,以及如何实现电子邮件验证,使得用户注册后发送带有激活链接的电子邮件。当他们点击链接时,他们的帐户将被激活,并可以使用用户名或电子邮件登录。此外,我还想知道如何通过在注册期间分配默认角色来为已注册用户实现简单的角色。

类似的问题: 如何使用SimpleMembership管理个人资料?

如何在ASP.NET MVC4中扩展SimpleMembership身份验证

但我真的很想与现有的simplemembership系统一起工作。

这篇文章非常接近: http://blog.longle.net/2012/09/25/seeding-users-and-roles-with-mvc4-simplemembershipprovider-simpleroleprovider-ef5-codefirst-and-custom-user-properties/

我也看到了这篇文章: http://weblogs.asp.net/jgalloway/archive/2012/08/29/simplemembership-membership-providers-universal-providers-and-the-new-asp-net-4-5-web-forms-and-asp-net-mvc-4-templates.aspx

这是我迄今为止找到的最接近的: http://weblogs.asp.net/thangchung/archive/2012/11/15/customize-the-simplemembership-in-asp-net-mvc-4-0.aspx

这对WebPages也很有用: http://blog.osbornm.com/archive/2010/07/21/using-simplemembership-with-asp.net-webpages.aspx

我希望能找到更全面的教程,以正确地扩展它。


你还需要这个问题的答案吗? - Komengem
1个回答

1

看起来你没有得到任何答案。

除非我没有完全理解你想做的事情,否则无需修改/扩展/自定义默认的SimpleMembership以提供电子邮件注册机制或在注册期间分配默认角色,因为所有这些都可以在AccountController内完成。

以下是我正在使用的注册方法示例:

    [HttpPost]
    [AllowAnonymous]
    [ValidateAntiForgeryToken]
    public ActionResult Register(RegisterModel model)
    {
        if (ModelState.IsValid) //TODO Change this to use a worker to send emails.
        {
            // Check if email exists already before creating new user
            using (UsersContext db = new UsersContext())
            {
                UserProfile email = db.UserProfiles.FirstOrDefault(u => u.Email.ToLower() == model.Email.ToLower());
                UserProfile uName =
                    db.UserProfiles.FirstOrDefault(u => u.UserName.ToLower() == model.UserName.ToLower());

                // Attempt to register the user
                try
                {
                    if (email == null && uName == null && this.IsCaptchaVerify("Captcha is not valid"))
                    {
                        bool requireEmailConfirmation = !WebMail.SmtpServer.IsEmpty();
                        string confirmationToken = WebSecurity.CreateUserAndAccount(model.UserName, model.Password, new
                        {
                            FirstName = model.FirstName,
                            LastName = model.LastName,
                            Email = model.Email                               
                        },
                        requireEmailConfirmation);
                        if (requireEmailConfirmation)
                        {
                            EmailViewModel eml = new EmailViewModel
                                                     {
                                                         ToEmail = model.Email,
                                                         Subject = "Confirmez votre inscription",
                                                         FirstName = model.FirstName,
                                                         LastName = model.LastName,
                                                         Body = confirmationToken
                                                     };

                            UserMailer.ConfirmRegistration(eml).SendAsync();

                            Response.Redirect("~/Account/Thanks");                            
                        }
                        else
                        {
                            WebSecurity.Login(model.UserName, model.Password);
                            Response.Redirect("~/");
                        }                           
                    }
                    else
                    {
                        if (email != null)
                            ModelState.AddModelError("Email", "Email address already exists. Please enter a different email address.");

                        if (uName != null)
                            ModelState.AddModelError("UserName", "User Name already exists. Please enter a different user name.");

                        if (!this.IsCaptchaVerify("Captcha is not valid"))
                            TempData["ErrorMessage"] = "Captcha is not valid";
                    }

                }
                catch (MembershipCreateUserException e)
                {
                    ModelState.AddModelError("", ErrorCodeToString(e.StatusCode));
                }
            }
        }

        // If we got this far, something failed, redisplay form
        return View(model);
    }

这里没有默认角色分配,但一旦EmailConfirmation得到验证,很容易添加。

由于这个问题相当古老,我希望它能帮助到某些人!


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接