开发者论坛

 找回密码
 注册 (请使用非IE浏览器)
查看: 4450|回复: 0

如何根据当前用户隐藏导航项

[复制链接]

0

精华

8

贡献

1767

赞扬

特约版主

帖子
583
软币
4524
在线时间
275 小时
注册时间
2019-2-21
发表于 2020-9-15 09:39:07 | 显示全部楼层 |阅读模式
DevExpress技术交流群2:775869749      欢迎一起进群讨论
DevExpress Universal Subscription拥有.NET开发需要的所有平台控件,包含600多个UI控件、报表平台、DevExpress Dashboard eXpressApp 框架、适用于 Visual Studio的CodeRush等一系列辅助工具。
屡获大奖的软件开发平台DevExpress Universal 2020年全新首发v20.1,最新版拥有众多新产品和数十个具有高影响力的功能,可为桌面、Web和移动应用提供直观的解决方案,全面解决各种使用场景问题。要体验?点击下载>>
系统背景
  • 平台:Frameworks (XAF & XPO)
  • 产品:DeXpressApp Framework
我们的 Security System 允许通过配置某些用户的导航权限为其隐藏导航项,可以用两种模式配置这些权限。
从v16.2开始,可以将导航权限分配给各个导航项目。默认情况下,在使用向导创建的新项目中启用此功能,要在从旧版本升级时启用它,必须将SecurityStrategy.SupportNavigationPermissionsForTypes选项设置为false。 如果项目基于Entity Framework,则也有必要更新数据库。
在v16.1和更早版本中,可以通过Type Permissions设置中提供的AllowNavigate选项将导航权限分配给特定的对象类型。 如果当前用户没有导航到该类型的权限,则从导航控件中删除特定于相应类型的所有导航项目。 将旧项目升级到v16.2和更高版本时,默认情况下启用此模式。要在使用向导创建的新项目中启用它,请打开应用程序设计器,并将SecurityStrategy.SupportNavigationPermissionsForTypes属性值更改为false。
本文将演示如何手动实现第一种模式,如果项目使用的XAF版本尚未实现导航权限功能,则本文中演示的方法很有用。
注意:如果使用此示例中提供的解决方案并升级到版本16.2,则此代码可能会停止正常运行。 在这种情况下,请使用本文结尾处提供的建议。
如果您的XAF版本低于16.2,并且您需要授予单个导航项(例如,DashboardView或特定ListView模型)的权限,请使用下面介绍的解决方案扩展安全系统的功能。 在本文中,HiddenNavigationItems属性允许您按其ID隐藏导航项,这将添加到角色类。
本文中显示的覆盖ShowNavigationItemController.SynchItemWithSecurity方法的方法也适用于与安全系统不直接相关的任务,您可以通过这种方式隐藏或自定义任何导航项目。
实现步骤:
  • 实现自定义权限类型NavigationItemPermission,可用于通过其ID检查特定导航项目的访问权限。
  • 实现一个自定义权限请求 - NavigationItemPermissionRequest - 该请求将发送以检查当前用户是否有权访问某个导航项目。
  • 实现一个自定义权限请求处理器NavigationItemPermissionRequestProcessor,它将确定当前用户是否对接收到的权限请求具有权限。
  • 使用HiddenNavigationItems属性实现自定义角色。 使用GetPermissions方法对其进行扩展,以基于HiddenNavigationItems属性的值创建NavigationPermission实例。
  • 在应用程序设计器安全系统的RoleType属性中指定自定义角色。
  • 通过处理Program.cs和Global.asax.cs文件中的SecurityStrategy.CustomizeRequestProcessors事件,在应用程序中注册权限请求处理器。
  • 实现ShowNavigationItemController的后代 - CustomShowNavigationItemController - 并重写其SynchItemWithSecurity方法以停用CustomSecurityRole.HiddenNavigationItems属性禁止的导航项。
在项目中执行了这些步骤之后,您将能够将具有HiddenNavigationItems属性的角色分配给所需的用户,以限制他们对某些导航项的访问。
注意:本文基于PermissionPolicyRole和PermissionPolicyUser类。在解决方案向导中选择Allow/Deny权限策略时,安全系统将使用这些类。 如果您的项目是使用较早的XAF版本(16.1之前的版本)创建的,并且使用了SecuritySystemRole和SecuritySystemUser类,请在下面的组合框中更改版本号,以查看这些类的示例。
v16.2的升级说明:
升级到此版本后,此示例旧版本中使用的代码可能会停止工作。 要解决此问题,请从示例的新版本中复制相关代码,或者通过添加以下方法来修改CustomShowNavigationItemController类:
C#
[C#] 纯文本查看 复制代码
protected override bool SyncItemsWithRequestSecurity(DevExpress.ExpressApp.Actions.ChoiceActionItemCollection items) { 
base.SyncItemsWithSecurity(items); 
return true; 
}

Visual Basic
[Visual Basic] 纯文本查看 复制代码
Protected Overrides Function SyncItemsWithRequestSecurity(ByVal items As DevExpress.ExpressApp.Actions.ChoiceActionItemCollection) As Boolean 
MyBase.SyncItemsWithSecurity(items) 
Return True 
End Function




回复

使用道具 举报

Archiver|手机版|小黑屋|开发者网 ( 苏ICP备08004430号-2 )
版权所有:南京韵文教育信息咨询有限公司

GMT+8, 2024-3-28 19:19

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表