1

ASP.Net MVC 3 を使用するプロジェクトがあり、ユーザー管理を行いたいと考えています。私はこのようにしたい: http://mrgsp.md:8080/awesome/user

そのユーザー管理を行う方法は?

どうもありがとう

4

2 に答える 2

2

MembershipUserを参照するだけでなく、ユーザーの作成と編集も可能にするモデルを作成しました。

namespace MyProject.Models
{
    public class AccountUser
    {
        [Key, DatabaseGenerated(DatabaseGeneratedOption.None)]
        public virtual Guid UserId { get; set; }

        [Display(Name="User Name")]
        public virtual string UserName { get; set; }

        [Display(Name = "E-mail")]
        public virtual string Email { get; set; }

        public virtual string Password { get; set; }

        [Display(Name = "Approved")]
        public virtual bool IsApproved { get; set; }

        /* contructors based on string GUID or actual */
        public AccountUser() { }
        public AccountUser(string UID)
        {
            UserId = new Guid(UID);
            Initialize();
        }

        public AccountUser(Guid UID)
        {
            UserId = UID;
            Initialize();
        }

        /* loads Membership User into model to access other properties */
        public virtual MembershipUser User
        {
            get
            {
                // note that I don't have a test for null in here, 
                // but should in a real case.
                return Membership.GetUser(UserId);
            }
        }

        /* do this once when opening a user instead of every time you access one of these three *
         * as well as allow override when editing / creating                                    */
        private void Initialize()
        {
            UserName = User.UserName;
            Email = User.Email;
            IsApproved = User.IsApproved;
        }

    }
}

これを構築して、デフォルトのデータコンテキストを使用してコントローラーを作成し、足場を作成できるようにしました。次に、コントローラーからコンテキストを削除しました。

namespace MyProject.Controllers
{ 
    [Authorize]
    public class AccountUserController : Controller
    {
        public ViewResult Index()
        {
            var memberList = Membership.GetAllUsers();
            var model = new List<AccountUser>();
            foreach (MembershipUser user in memberList)
            {
                model.Add(new AccountUser(user.ProviderUserKey.ToString()));
            }
            return View(model);
        }

        public ViewResult Details(Guid id)
        {
            AccountUser accountuser = new AccountUser(id);
            return View(accountuser);
        }

        public ActionResult Create()
        {
            return View();
        } 

        [HttpPost]
        public ActionResult Create(AccountUser myUser)
        {
            if (ModelState.IsValid)
            {
                Membership.CreateUser(myUser.UserName, myUser.Password, myUser.Email);

                return RedirectToAction("Index");  
            }

            return View(myUser);
        }

        public ActionResult Edit(Guid id)
        {
            AccountUser accountuser = new AccountUser(id);
            return View(accountuser);
        }

        [HttpPost]
        public ActionResult Edit(AccountUser accountuser)
        {
            if (ModelState.IsValid)
            {
                return RedirectToAction("Index");
            }
            return View(accountuser);
        }

        public ActionResult Delete(Guid id)
        {
            AccountUser accountuser = new AccountUser(id);
            return View(accountuser);
        }

        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(Guid id)
        {
            AccountUser accountuser = new AccountUser(id);
            Membership.DeleteUser(accountuser.User.UserName);

            return RedirectToAction("Index");
        }

        protected override void Dispose(bool disposing)
        {
            //db.Dispose();
            base.Dispose(disposing);
        }
    }
}

ビューはすべて非常に単純である必要がありますが、一貫性を保つためにここにあります

@model MyProject.Models.AccountUser

@{
    ViewBag.Title = "Create";
}

<h2>Create</h2>

<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>

@using (Html.BeginForm()) {
    @Html.ValidationSummary(true)
    <fieldset>
        <legend>AccountUser</legend>

        <div class="editor-label">
            @Html.LabelFor(model => model.UserName)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.UserName)
            @Html.ValidationMessageFor(model => model.UserName)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Password)
        </div>
        <div class="editor-field">
            @Html.PasswordFor(model => model.Password)
            @Html.ValidationMessageFor(model => model.Password)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Email)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Email)
            @Html.ValidationMessageFor(model => model.Email)
        </div>

        <p>
            <input type="submit" value="Create" />
        </p>
    </fieldset>
}

<div>
    @Html.ActionLink("Back to List", "Index")
</div>

それは間違いなく全体的に少しトリッキーでした。ほとんどの場合、モデルを正しくしてメンバーシップから読み込めるようにし、適切なビューのセットを作成できるようにしました。私は実際にそれらのほとんどを手作業で行いましたが、これはあなたにいくらかの時間を節約するでしょう。パスワードまたはロールの編集を省略したことに注意してください。ただし、ここまで進んだ場合は、それほど遠くないはずです。

次のリンクが役に立ちました。

于 2012-05-09T19:02:45.597 に答える
1

新しいプロジェクト mvc3 を作成し、パッケージ マネージャーから素晴らしいプロジェクトをダウンロードします。

PM> Install-Package MvcProjectAwesome 
于 2011-09-27T07:38:16.173 に答える