我正在尝试设置我的网站,其中显示管理员角色的所有链接以及用户角色的有限数量显示。
这是我的站点地图:
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode >
<siteMapNode url="fake1.aspx" title="Example A" description="Example" roles="user">
<siteMapNode url="fake2.aspx" title="Example 1" description="Example" roles="user" />
<siteMapNode url="fake3.aspx" title="Example 2" description="Example" roles="user" />
<siteMapNode url="fake4.aspx" title="Example 3" description="Example" roles="user" />
</siteMapNode>
<siteMapNode url="fake5.aspx" title="Example B" description="Example" roles="user">
<siteMapNode url="fake6.aspx" title="Example 1" description="Example" roles="user" />
<siteMapNode url="fake7.aspx" title="Example 2" description="Example" roles="user" />
<siteMapNode url="fake8.aspx" title="Example 3" description="Example" roles="user" />
</siteMapNode>
<siteMapNode url="fake9.aspx" title="Example C" description="Example" roles="user">
<siteMapNode url="fake10.aspx" title="Example 1" description="Example" roles="user" />
<siteMapNode url="fake11.aspx" title="Example 2" description="Example" roles="user" />
<siteMapNode url="fake12.aspx" title="Example 3" description="Example" roles="user"/>
</siteMapNode>
<siteMapNode url="fake13.aspx" title="Example D" description="Example" roles="admin">
<siteMapNode url="fake14.aspx" title="Example 1" description="Example" roles="admin" />
<siteMapNode url="fake15.aspx" title="Example 2" description="Example" roles="admin" />
<siteMapNode url="fake16.aspx" title="Example 3" description="Example" roles="admin" />
</siteMapNode>
</siteMapNode>
</siteMap>
这是我的菜单服务器控件:
<div id="menuBar">
<asp:Menu ID="Menu1" runat="server" DataSourceID="SiteMapDataSource1" StaticDisplayLevels="2"
Orientation="Horizontal" >
</asp:Menu>
<asp:SiteMapDataSource ID="SiteMapDataSource1" runat="server" />
</div>
以下是我的角色截图:
从我一直在阅读的教程中,角色=“”应该按照每个角色来处理链接访问,但我的网站上没有发生任何事情。用户和管理员也看到了同样的事情。我做错了什么?
答案 0 :(得分:1)
在显示管理员相关内容之前,请检查用户是否处于正确的角色: -
if (Membership.GetUser() != null && Page.User.IsInRole("admin"))
{
//User is an admin
}