如何区分授权角色在左侧,未授权在右侧

如何实现以下效果


代码如下:

/**
 * 辅助查询
 * @param list
 * @return
 */
public Map<String,String> changMapByUserRole(List<SysUserRoleR> list){
    Map<String,String> resultMap = new HashMap<>();
    for(SysUserRoleR roleR:list){
	//设置一个标志
        resultMap.put(roleR.getRoleId(),"1");
    }
    return resultMap;
}
思路:把所有的角色查询出来,然后利用map的属性来进行区分。

解释:

形参:将关联表中的所有角色查询出来。

以下代码是主查询的实现

/**
 * 主要代码
 * @param req 接受的是json串,传json传的http请求只能是POST
 * @return
 */
@RequestMapping(value = "/findAllRole",method = RequestMethod.POST)
@ResponseBody
public Object findAllRole(@RequestBody String req){
    SysUserRoleR sur = null;
    try{
	//这里将json传转换为对象,只有key与对象的属性一致才能转换成功,否则失败
        sur = jsonTranster.readValue(req,SysUserRoleR.class);
    }catch (Exception e){
        e.printStackTrace();
        return addResultMapMsg(false,e.getMessage());
    }
	//判断对象是否为空或者用户的主键未传
    if(BeanUtils.isBlank(sur) || StringUtils.isEmpty(sur.getUserId())){
        return addResultMapMsg(false,"未传入userId");
    }
    //查询出所有角色
    List<Role> rolelist = roleService.findAll();
    if(rolelist.size() == 0 || rolelist.isEmpty()){
        return addResultMapMsg(false,"用户角色列表查询失败");
    }
    //根据用户id查询角色
    List<SysUserRoleR> list = sysUserRoleRService.findByUserId(sur.getUserId());
    if(list == null){
        return addResultMapMsg(true,rolelist);
    }
	//调用上面的辅助查询方法
    Map<String,String> roleMap =  changMapByUserRole(list);
	//遍历所有的角色
    for(Role role:rolelist){
	//利用辅助查询里面的设置来判断角色是否授权,如果有id就和“1”进行来进行判断
        if("1".equals(roleMap.get(role.getId()))){ //当前用户有的角色
	//判断有这个id设置Role中的标示字段为true,否则为false,前端会根据这个字段的属性进行区分	
            role.setRoleFlag(true);
        }else{
            role.setRoleFlag(false);
        }
    }
   return addResultMapMsg(true,rolelist);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值