为了账号安全,请及时绑定邮箱和手机立即绑定

【备战春招】第3天 通用权限设计

标签:
Java

课程名称:Spring Cloud+ Vue前后端分离开发企业级在线视频系统

课程章节:第12章 通用权限设计

讲师姓名:甲蛙老师

课程内容

资源配置管理:在写项目的权限管理模块、用户系统的时候经常碰见类似的树结构我们一般习惯称之为权限树。

课程收获

按照一定的规则从数据库中取值,返回给前端的树形空间zTree。数据库中存储的资源的id是按照位数排序,如图所示。

之前说到反复的去数据库获取数据会让网络开销变大,所以我们应该一次性将所有需要的权限数据全部取出(有的时候是取出全部的数据,有时取得某个角色的权限数据),将取到数据放入一个list中,之后再进行数据处理。

https://img1.sycdn.imooc.com//63e3b92600018f8f13890843.jpg

/**
 *
按约定将列表转成树
 * 要求:ID要正序排列
 * @return
 */
public List<ResourceDto> loadTree() {
   
ResourceExample example = new ResourceExample();
   
example.setOrderByClause("id asc");
   
List<Resource> resourceList = resourceMapper.selectByExample(example);
   
List<ResourceDto> resourceDtoList = CopyUtil.copyList(resourceList, ResourceDto.class);
   
for (int i = resourceDtoList.size() - 1; i >= 0; i--) {
       
// 当前要移动的记录
       
ResourceDto child = resourceDtoList.get(i);

       
// 如果当前节点没有父节点,则不用往下了
       
if (StringUtils.isEmpty(child.getParent())) {
           
continue;
        }
       
// 查找父节点
       
for (int j = i - 1; j >= 0; j--) {
           
ResourceDto parent = resourceDtoList.get(j);
           
if (child.getParent().equals(parent.getId())) {
               
if (CollectionUtils.isEmpty(parent.getChildren())) {
                   
parent.setChildren(new ArrayList<>());
                }
               
// 添加到最前面,否则会变成倒序,因为循环是从后往前循环的
               
parent.getChildren().add(0, child);

               
// 子节点找到父节点后,删除列表中的子节点
               
resourceDtoList.remove(child);
            }
        }
    }
   
return resourceDtoList;
}

小知识:如果要一边循环list,一边删除list中的对象,可以使用倒序循环。例如本节的资源树


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消