权限与菜单

1.在项目添加权限

shiro处理权限流程:

(1)把所有的权限交给shiro管理 --createFilterChainDefinitionMap 可以体现处理

(2)在realm里面 就要查询当前用户的权限,如果这个权限在shiro管理返回之内,这个用户就有响应的权限

否则就没有

 

1.1 从数据库查询所有权限交给shiro管理

 List<Permission> permissions = permissionService.findAll();
        for (Permission permission : permissions) {
            mp.put(permission.getUrl(), "perms["+permission.getSn()+"]");
        }

1.2 查询当前用户具备权限

--sql查询当前用户的权限
select p.* from employee e
join employee_role er on e.id = er.employee_id
join role r on er.role_id = r.id
join role_permission rp on rp.role_id = r.id
join permission p on p.id = rp.permission_id 
where e.id = 2
 protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
        //授权方法
        Employee employee =(Employee) principalCollection.getPrimaryPrincipal();
        //根据用户名得到权限代码
        //从数据库查询当前用户的所有的权限
       // Set<String> permissions = getPermissionsByUsername(employee.getUsername());
        Set<String> permissionSet = permissionService.findPermissionByEmployeeId(employee.getId());
        //shiro就会自己取进行权限的比较
        SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo();
        authorizationInfo.setStringPermissions(permissionSet);
        return authorizationInfo;
    }

1.3 权限出问题之后,ajax怎么返回

(1)写一个过滤器 覆写PermissionsAuthorizationFilter

(2)重写 onAccessDenied方法

方法里面 就判断如果是ajax请求 就直接返回json格式,

否则就走原来的格式,返回页面

 

1.4 页面权限的按钮控制

添加标签来控制页面的按钮是否显示

 <shiro:hasPermission name="employee:delete">
             <a href="#" data-method="delete" plain="true"   class="easyui-linkbutton" iconCls="icon-remove">删除</a>
  </shiro:hasPermission>

2 左侧树形菜单

现在菜单写死了,写到json文件里面,但是如果如果想添加一个菜单,还有修改的json文件,比较麻烦,所有把菜单存入数据库,读取数据库就OK

2.1 menu对象的确定

写了Menu domain对象

public class Menu extends BaseDomain {

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

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name="parent_id")
    @JsonIgnore //忽略json 在展示json格式的 parent不会展示出来 会造成死循环
    private Menu parent;

    @Transient //这个是临时属性,不交给jpa管理 ,自己来维护 -- 手动添加子菜单
    private List<Menu> children = new ArrayList();

    //兼容esayui的菜单树[id:1,text:'xxx']
    public String getText(){
        return this.name;
    }
    //setget...
    }

2.2 service构造json的方法

public List<Menu> findMenuByLoginUser(Long employeeId) {
        List<Menu> menus = new ArrayList();
        //查询当前用户的所有的子菜单
        List<Menu> subMenus = menuRepository.findByLoginUser(employeeId);
        //循环子菜单  2,3,4,5    1   (7 8)  6
        for (Menu subMenu : subMenus) {
            //从子菜单里面拿到父菜单 6
            Menu parentMenu = subMenu.getParent();
            if(!menus.contains(parentMenu)) {
                menus.add(parentMenu);
            }
            parentMenu.getChildren().add(subMenu);//[1,[2,3,4,5],6 [7,8]]
        }

        return menus;
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值