我目前正在使用带有 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>