5

我目前正在使用带有 Razor 引擎和 C# 的 MVC 4 作为逻辑背后的代码。SimpleMembership 数据库的定制版本已构建以满足网站的要求。

该网站可以按预期创建和编辑角色和用户,但是我在为用户分配角色时遇到问题。一些搜索结果提供了在创建帐户时将特定角色分配给用户的代码。我们的要求不是这样,而是需要通过网站使用 UI 手动分配它们。

有很多 ASP.Net 教程(下面的示例),但是我发现很难找到 MVC 4 的相关教程。

http://www.asp.net/web-forms/tutorials/security/roles/assigning-roles-to-users-cs

看完以上内容,我想问以下问题。

问题一:是否有通过 UI 分配用户角色的 MVC 教程?如果是这样,您能否提供指向该教程的链接。

问题二:如果您没有指向教程的链接,您能否就以下内容提供一些建议:

  • 当管理员加载用户管理 UI 时,表格将加载用户列表,当他们单击特定用户的编辑按钮时,以下内容将生效并将数据传回名为“Edit.cshtml”的视图。

    public ActionResult Edit(int id = 0)
    {
      var userProfile = _db.UserProfiles.Find(id);
      if (userProfile == null)
      {
        Response.Redirect("~/UserManagement/PageNotFound");
      }
    
      return View(userProfile);
    }
    
    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Edit(UserProfile userProfile)
    {
      if (ModelState.IsValid)
      {
        _db.Entry(userProfile).State = EntityState.Modified;
        _db.SaveChanges();
        return RedirectToAction("Index");
      }
    
      return View(userProfile);
    }
    

在“编辑”视图中,我正在考虑将部分视图呈现到页面上,并带有数据库中各种角色的复选框。类似于以下内容:

@model IEnumerable<PROJECTNAME.DAL.Models.Role>

@foreach (var item in Model)
{
    @Html.LabelFor(m => item.RoleName)

    <label class="bolder">
        Visible
        @Html.CheckBoxFor(m => item.Visible)
        <span class="lbl"></span>
    </label>
}

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
    @Html.ValidationSummary(true)

    <fieldset>
     <!-- CODE HERE IS TO EDIT USER DETAILS -->

     <div id="assignableroles">
        @{
         Html.RenderPartial("_AssignableRoles");
        }
     </div>
    </fieldset>    
}

一旦相关的复选框/ es 被标记,这应该更新到数据库中并允许用户访问该特定区域(只要相应地添加了授权属性)。

我确实在网上找到了这个,但是我不确定在控制器中的哪个位置添加它,或者它是否与我的困境有关,因为我正在考虑使用两个视图,因为我需要处理两个不同的模型。

  var role = (SimpleRoleProvider)Roles.Provider;

  if (!role.RoleExists(selectedRole))
    role.CreateRole(selectedRole);

  WebSecurity.CreateUserAndAccount(model.UserName, model.Password);
  role.AddUsersToRoles(new[] { model.UserName }, new[] { selectedRole });

很抱歉这篇长文,但这是我第一次在 MVC 中使用 Membership,我对这个工具还是很陌生。

编辑:

我还确保将其添加到 web.config 文件中:

<roleManager enabled="true" defaultProvider="SimpleRoleProvider">
  <providers>
    <clear />
    <add name="SimpleRoleProvider"
         type="WebMatrix.WebData.SimpleRoleProvider, WebMatrix.WebData"
         connectionStringName="DefaultConnection" applicationName="PROJECTNAME" />
  </providers>
</roleManager>
4

1 回答 1

7

最简单的方法是使用以下方法进行操作:

Roles.AddUserToRole(UserName, RoleName)- 添加角色

Roles.RemoveUserFromRole(UserName, RoleName)- 删除角色

例如,要为用户添加角色,您可能在控制器中具有以下操作结果:

[HttpPost]
public ActionResult(string UserName, string RoleName)
{
 Roles.AddUserToRole(UserName, RoleName) 
return View()
}

string UserName, string Role - 应该通过 post 方法从 View 传递。

于 2013-08-07T16:23:50.803 回答