我知道标签有“角色”。属性以弥补没有“url”的节点。属性,可以通过其他方式解决。我对这些其他方式不感兴趣,但我想在我的站点地图文件中设置所有权限。如何做到这一点?

我正在使用自定义RoleProvider,自定义MembershipProvider和默认的XmlSiteMapProvider。我还有一个安全IHttpModule来防止人们使用直接URL到达那里。我对不同的方法持开放态度。

提前致谢!

有帮助吗?

解决方案

您可以实现自己的XmlSiteMapProvider并覆盖IsAccessibleToUser方法。

public override bool IsAccessibleToUser(HttpContext context, SiteMapNode node)
{
     return <condition in which access is allowed>
}

其他提示

最后,我通过派生自XmlSiteMapProvider实现了我自己的安全修整。这很简单。

public override SiteMapNodeCollection GetChildNodes(SiteMapNode node)
{
    return CustomSecurityTrim(base.GetChildNodes(node));
}
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top