权限菜单

一.权限菜单

每个用户登录后是根据自己的权限查得到相应的菜单

1.1 Role实体类的修改

  • @Transient:一对多不需要JPA管理,由我们自己添加数据
  • @JsonIgnore:双向关联不要生成JSON,会搞成死循环,根据业务需求放某一方放弃生成
@Entity
@Table(name = "menu")
public class Menu extends BaseDomain {

    //菜单名称
    private String name;
    //菜单路径
    private String url;
    //图标
    private String icon;

    /**
     * 配置多对一(性能,业务需求【需要通过子菜单拿到父菜单】)
     *  让生成JSON的时候,不要去找父亲
     */
    @ManyToOne
    @JoinColumn(name = "parent_id")
    @JsonIgnore
    private Menu parent;

    /**
     * 不要配置单向一对多(性能不好)
     * 你现在敢配置一对多嘛?配置了一对多,关系则由JPA来管理!
     * 它会自动从1方去拿到所有多方!!!
     *   1.这里是否需要儿子的List字段 -》 一定要的
     *   2.这个儿子的List是否要JPA管理 -》 不可以
     *   加上这个字段(属性),但是不交给JPA管理【咱们手动管理这个字段】
     */
    //parent_id
    //配置一对多 Transient:临时属性(JPA不会管它)
    @Transient
    private List<Menu> children = new ArrayList<>();

    ...
}

1.2 MenuRepository

  • 根据员工获取到他对应的所有权限菜单(这里只有子菜单)
  • 这条JPQL要求你的关系都是配置好的(与实体类匹配上)
 /**
     * 根据用户拿到对应的所有权限菜单
     */
    @Query("select distinct m from Employee e join e.roles r join r.permissions p join p.menu m where e.id=?1")
    List<Menu> findMenusByUser(Long userId);

 /**
     * 查找全部的父菜单
     * @return
     */
    @Query("select m from Menu m where m.url is null")
    List<Menu> findParentMenus();

1.3 MenuService

  • 拿到当前登录用户然后进行查询
  • 拼接成前台需要的效果(一定要记住你最后想要的是什么效果)
    @Override
    public List<Menu> findLoginUserMenus() {
        //一.准备一个装父菜单的容器(List)
        List<Menu> parentMenuList = new ArrayList<>();
        //二.拿到并循环子菜单
        //2.1 拿到当前登录用户
        Subject subject = SecurityUtils.getSubject();
        Employee loginUser = (Employee) subject.getPrincipal();
        //2.2 根据用户拿到他的菜单 iter
        List<Menu> menus = menuRepository.findMenusByUser(loginUser.getId());
        for (Menu menu : menus) {
            //三.开始设置数据结构
            //3.1 根据子菜单拿父菜单
            Menu parentMenu = menu.getParent();
            //3.2 判断父菜单容器中是否有这个父菜单
            if(!parentMenuList.contains(parentMenu)){
                //如果没有,我们要把当前这个父菜单放到容器中
                parentMenuList.add(parentMenu);
            }
            //3.3 把子菜单放到父菜单中
            parentMenu.getChildren().add(menu);
        }
        return parentMenuList;
    }

1.4 前台正常展示

@RequestMapping("/findParentMenus")
@ResponseBody
public List<Menu> findParentMenus() {
    return menuService.findLoginUserMenus();
}

1.5前台需要接受的json格式数据

[{
  "id": 1,
  "text": "系统管理",
  "state": "open",
  "children": [{
    "id": 12,
    "text": "部门管理",
    "iconCls":"icon-lock",
    "url":"/department/index"
  },{
    "id": 11,
    "text": "员工管理",
    "iconCls":"icon-man",
    "url":"/employee/index"
  }]
}]
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: SAP GUI是SAP系统的图形用户界面,它提供了多种功能和菜单选项,以帮助用户执行各种操作和任务。在SAP GUI中,权限菜单是一个重要的功能,可以用于控制用户对系统的访问权限和操作权限权限菜单允许系统管理员根据用户的角色和职责,为用户分配特定的权限。通过权限菜单,管理员可以指定用户可以访问和操作的各个模块、功能和事务。这有助于确保每个用户只能访问其需要的功能和数据,保护系统的安全性和完整性。 在SAP GUI中,权限菜单通常由管理员在系统设置中进行配置和维护。通过指定角色和权限组合,管理员可以将用户分为不同的用户组,并对每个用户组分配适当的权限。这些权限可以包括读取、写入、修改和删除数据的权限,以及执行特定事务或功能的权限。 用户登录SAP GUI后,根据其分配的角色和权限组合,系统将自动加载相应的权限菜单。用户只能看到他们被授权访问的功能和事务,而无法看到其他不相关的功能。这样可以避免用户错误或恶意访问未经授权的功能或数据,从而提高系统的安全性。 总之,SAP GUI的权限菜单是一个重要的功能,它允许管理员根据用户的角色和职责,为用户分配特定的权限。通过正确配置和维护权限菜单,可以确保用户只能访问其需要的功能和数据,提高系统的安全性和完整性。 ### 回答2: SAP GUI权限菜单是指SAP GUI(SAP图形用户界面)中的权限管理菜单,通过这个菜单可以对用户或用户组的权限进行管理和控制。 在SAP GUI权限菜单中,管理员可以进行以下操作: 1. 用户权限设置:管理员可以添加、修改或删除用户的权限。例如,可以授予一个用户只能查看数据但无法修改的权限,或者允许某个用户访问特定的功能模块或事务代码。 2. 用户组权限分配:管理员可以将用户分组并为每个组分配特定的权限。这样可以简化权限管理,一次性为整个用户组分配相同的权限。例如,一个销售部门的用户组可以被授予访问销售模块的权限,而财务部门的用户组可以被授予访问财务模块的权限。 3. 权限继承设置:管理员可以设置权限的继承关系,使权限自动继承给下级用户或用户组。这样可以减少权限管理的工作量。例如,可以设置某个用户组的权限自动继承给该用户组下的所有用户。 4. 权限审计:管理员可以通过权限菜单查看和审计用户的权限。这可以帮助管理员了解用户所拥有的权限,并做出必要的调整。 总之,SAP GUI权限菜单是一个重要的工具,用于在SAP系统中管理和控制用户的权限。通过这个菜单,管理员可以设置和分配用户的权限,管理用户组,继承权限,以及审计用户的权限。这有助于确保系统安全,并确保用户只能访问他们所需的功能和数据。 ### 回答3: SAP GUI权限菜单是一种用于管理用户权限的功能。通过这个菜单,SAP系统管理员可以限制用户能够访问和执行的特定功能和数据。以下是关于SAP GUI权限菜单的一些详细信息: 首先,SAP GUI权限菜单提供了对用户角色和权限的集中管理。管理员可以为不同的用户分配不同的角色,并且每个角色可以有特定的权限。通过这样的角色权限分配,可以确保用户只能访问他们需要的功能和数据,从而提高数据安全性。 其次,SAP GUI权限菜单允许管理员根据需要自定义角色和权限。管理员可以根据组织的具体要求创建和修改角色,并且可以为每个角色分配特定的权限。这样,可以根据不同的部门或职位需求为用户配置相应的权限,以便他们能够有效地完成工作。 另外,SAP GUI权限菜单还提供了对系统日志的查看和分析功能。管理员可以查看用户的登录历史和操作日志,以监控用户的使用情况并及时发现潜在的安全风险。 最后,SAP GUI权限菜单还提供了权限冲突检测和解决的功能。如果存在角色权限的冲突,系统会自动检测并提示管理员进行解决。这样可以避免不同权限之间的冲突,从而确保数据的完整性和一致性。 综上所述,SAP GUI权限菜单是一个重要的功能,可以帮助管理员有效地管理用户的权限。通过这个菜单,管理员可以灵活地分配和管理不同用户的角色和权限,提高数据安全性和工作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心之所向...

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值