2011-09-27 109 views

回答

1

创建一个新项目MVC3,并从包管理器下载真棒项目:

PM> Install-Package MvcProjectAwesome 
+0

感谢答复,但我在哪里可以找到PM>安装,包装MvcProjectAwesome? –

+0

如果您使用Visual Studio 2010打开查看 - >其他窗口 - >程序包管理器控制台。 否则您可以从网站http://awesome.codeplex.com/releases/view/66067 –

+0

下载Awesome项目感谢您的回复。我已经为用户角色制作了checkboxlist,但是当我提交表单时我没有获得价值。 –

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; 
     } 

    } 
} 

这个内置的,我创建了一个控制器与我的默认数据上下文,让它为我创建脚手架。然后我从Controller中删除了Context。

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> 

这肯定是有点棘手,总体而言,大多是与得到的模型正确,让您从成员阅读以及获得一组合理的视图。我其实大部分都是通过手工完成的,但这会为您节省一些时间。请注意,我省略了编辑密码或角色,但如果你得到这么远的话,你不应该离得太远。

下面的联系是有益的: