Изменить ссылку на карте сайта в зависимости от того, вошел ли пользователь в систему?
У меня есть карта сайта, на которой есть ссылка, когда пользователь не вошел в систему, но когда он входит, ссылка должна измениться, например, nonmember.aspx должен измениться на member.aspx. Эта карта сайта связана с меню asp:. Кто-нибудь знает как это сделать?
2 ответа
Простое решение состоит в том, чтобы иметь два узла в вашей карте сайта.
- Один узел отображается для анонимных пользователей.
- Один узел отображается для аутентифицированных пользователей с безопасным доступом
Я верю, что вы можете настроить это довольно просто.
Конечный результат аналогичен изменению ссылки, но его легче поддерживать.
Чтобы добавить к этому:
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode title="Home" url="~/" roles="*">
<siteMapNode url="~/Member.aspx" title="Home" roles="SpecialPeople" />
<siteMapNode url="~/Nonmember.aspx" title="Site Map" roles="HideForUsers" />
</siteMapNode>
</siteMap>
Итак, вы установили правило, запрещающее доступ кHideForMembers
"роль для аутентифицированных пользователей. Это что-то в этом роде. ASP.NET примет первое правило, в котором найдет совпадение, поэтому вы сможете выполнить его таким образом.
В противном случае вы могли бы сделать Menu_OnDataBound
и искать узел:
Protected Sub menMainDataBound(ByVal sender As Object, ByVal e As System.EventArgs)
Try
Dim myPage As New Page
Dim myPrincipal As IPrincipal
Dim colNodes As New Collection
myPrincipal = myPage.User
If myPrincipal.Identity.IsAuthenticated = True Then
Dim menNode As MenuItem
For Each menNode In menMain.Items
Select Case menNode.Value.ToString
Case "Products"
colNodes.Add(menNode)
Case "Contact Us"
colNodes.Add(menNode)
Case "About Us"
colNodes.Add(menNode)
Case "Links"
colNodes.Add(menNode)
End Select
Next
For Each menNode In colNodes
menMain.Items.Remove(menNode)
Next
End If
Catch ex As Exception
End Try
End Sub
Ниже приведен код web.config, который вы ищете:
<location path="Registration.aspx">
<system.web>
<authorization>
<allow users="?" />
<deny users="*" />
</authorization>
</system.web>
</location>