我正在使用ASP.Net MVC 4应用程序。 _Layout主视图包含一个菜单,如果您以用户身份登录,我想隐藏菜单中的一些项目,如果您以管理员身份登录,则显示。
我尝试过的方法确实隐藏了客户端菜单中的链接选项卡,但是当我以管理员身份登录时,当我希望管理员查看它时,它也会隐藏相同的链接选项卡。
提到我没有任何角色或管理控制器,登录基于用户
希望提前感谢一些帮助。
<nav>
<ul id="menu">
<li>@Html.ActionLink("Rep Home", "Index" , "Audit")</li>
<li>@Html.ActionLink("Log Out", "Login" , "Home")</li>
@if (ViewContext.HttpContext.User.IsInRole("Admin"))
{
<li><a href="http://example/reports/?report=auditDetails" target="_blank">View your report</a></li>
}
</ul>
public class AccountController : Controller
{
//
// GET: /Account/Login
[AllowAnonymous]
public ActionResult Login(string returnUrl)
{
ViewBag.ReturnUrl = returnUrl;
return View();
}
//
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model, string returnUrl)
{
if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
{
FormsAuthentication.SetAuthCookie(model.UserName, false);
return RedirectToLocal(returnUrl);
}
// If we got this far, something failed, redisplay form
ModelState.AddModelError("", "The user name or password provided is incorrect.");
return View(model);
}
<system.web>
<compilation debug="true" targetFramework="4.5" />
<httpRuntime targetFramework="4.5" />
<authentication mode="Forms">
<forms loginUrl="~/User/Login" timeout="2880" />
</authentication>
<pages>
<namespaces>
<add namespace="System.Web.Helpers" />
<add namespace="System.Web.Mvc" />
<add namespace="System.Web.Mvc.Ajax" />
<add namespace="System.Web.Mvc.Html" />
<add namespace="System.Web.Optimization" />
<add namespace="System.Web.Routing" />
<add namespace="System.Web.WebPages" />
</namespaces>
</pages>
答案 0 :(得分:2)
在“布局”页面中尝试此操作
@if(User.Identity.IsAuthenticated)
{
<li>Link to show only to logged users</li>
if(User.IsInRole("Admin"))
{
<li>Link show only to Admin </li>
}
}
else
{
links that will show to authenticated and unauthenticated users
}
在您的控制器中添加以下行
Public ActionResult Login(UserModel model)
{
// Check user provided credentials with database and if matches write this
FormsAuthentication.SetAuthCookie(model.id, false);
return View();
}
最后在你的Web.config中添加System.Web
中的这些行<authentication mode="Forms">
<forms loginUrl="Path of your Login view" timeout="2880"></forms>
</authentication>
请记住,您有2个Web.config
个文件,您必须在较低的Web.config
文件中添加这些文件。