我创建了一个简单的MVC应用程序,它使用随新项目提供的.Net Membership Provider。
我正在尝试正确显示标签。我可能不明白这一点,但这是我的代码:
<!DOCTYPE html>
<html>
<head>
<title>@ViewBag.Title</title>
<link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
</head>
<body>
<div class="page">
<div id="header">
<div id="title">
<h1>Suburban Customer Portal</h1>
</div>
<div id="logindisplay">
@Html.Partial("_LogOnPartial")
</div>
<div id="menucontainer">
<ul id="menu">
@if (Request.IsAuthenticated)
{
<li>@Html.ActionLink("ChangePassword", "ChangePassword", "Account")</li>
}else {
<li>@Html.ActionLink("Logon", "Logon", "Account")</li>
<li>@Html.ActionLink("Register", "Register", "Account")</li>
}
<li>@Html.ActionLink("ContactUs", "ContactUs", "Home")</li>
</ul>
</div>
</div>
<div id="main">
@RenderBody()
</div>
<div id="footer">
</div>
</div>
</body>
</html>
在这一行:
@if (Request.IsAuthenticated)
我正在尝试显示正确的标签,如果它们已经过身份验证。这总是如实......
我该怎么做?我显然没有以正确的方式做到这一点......
再次感谢!
答案 0 :(得分:19)
我认为你应该使用
@if(User.Identity.IsAuthenticated)
答案 1 :(得分:2)
嗯,你的问题不是很清楚,但是Request.IsAuthenticated在这一行:
@if(Request.IsAuthenticated)
检查请求是否包含有关经过身份验证的用户的数据。如果为true,则会显示您的链接。
在您的特定情况下,只有在用户登录时才会显示Change Password
链接。
看起来是正确的。
对于要隐藏的标签,即Request.IsAuthenticated = false
,您必须先logout
,以便从用户浏览器中清除存储登录信息的Cookie。