• 前后端分离之权限管理


    目录

    1.前端界面

    1.1 按钮

    1.2 对话框+树形控件

    2.后端操作

    2.1 controller层

    2.2 serviceImpl层

    2.3 结果展示

    2.4 查对应的权限菜单(使用中间表)

    2.4.1 后端处理(权限回显)

    2.4.2 前端处理

    2.4.3 后端处理(确定修改权限)


    1.前端界面

    1.1 按钮

    借助elementui中的表格部分

    1.2 对话框+树形控件

    借助elementui中的对话框和树形结构

    1. <el-dialog
    2. title="提示"
    3. :visible.sync="dialogPerVisible"
    4. width="30%"
    5. >
    6. <el-tree
    7. :data="treeData"
    8. show-checkbox
    9. node-key="id"
    10. :props="defaultProps">
    11. el-tree>
    12. <span slot="footer" class="dialog-footer">
    13. <el-button @click="dialogPerVisible = false">取 消el-button>
    14. <el-button type="primary" @click="dialogPerVisible = false">确 定el-button>
    15. span>
    16. el-dialog>
    1. data(){
    2. return{
    3. //自写权限树遮罩层
    4. dialogPerVisible:false,
    5. treeData:[],
    6. defaultProps: {
    7. children: 'children',
    8. //如果不显示命名,注意看请求结果是否为label不是则修改‘label’中的内容
    9. label: 'label'
    10. }
    11. }
    12. }
    1. methods:{
    2. //自写权限点击
    3. permissionClick(row){
    4. this.dialogPerVisible=true;
    5. this.$http.get("/system/permission/findPermessionByRoleId/"+row.id).then(result=>{
    6. this.treeData=result.data.data.treeData;
    7. })
    8. }
    9. }

    2.后端操作

    2.1 controller层

    1. //自写权限树
    2. @GetMapping("findPermessionByRoleId/{roleId}")
    3. public CommonResult findPermessionByRoleId(@PathVariable String roleId){
    4. return iPermissionService.findPermessionByRoleId(roleId);
    5. }

    2.2 serviceImpl层

    此处使用TODO可以在后面进行查找此业务是否完成

    1. //自写树结构的获取
    2. @Override
    3. public CommonResult findPermessionByRoleId(String roleId) {
    4. //查询所有的权限
    5. QueryWrapper wrapper=new QueryWrapper<>();
    6. //逻辑删除列考虑在内 还有一个状态列数据库暂未考虑
    7. wrapper.eq("is_deleted",0);
    8. List permissionList = permissionMapper.selectList(wrapper);
    9. //设置层级关系
    10. List firstMenus=new ArrayList<>();
    11. for (Permission first:permissionList) {
    12. //int
    13. if(first.getPid().equals("1")){
    14. firstMenus.add(first);
    15. }
    16. }
    17. //为一级菜单设置二级菜单
    18. for (Permission first : firstMenus) {
    19. //根据一级菜单id 查询 该菜单的二级菜单,如果出现不确定有几级菜单 那么我们可以使用方法的递归调用
    20. first.setChildren(findChildren(permissionList,first.getId()));
    21. }
    22. //TODO根据角色查询该角色具有的权限id
    23. Map map=new HashMap<>();
    24. //treeData为前端要接收的值
    25. map.put("treeData",firstMenus);
    26. return new CommonResult(2000,"查询成功",map);
    27. }
    28. //方法递归
    29. public void getCheckKey(Permission p,List list){
    30. if(p.getChildren() == null || p.getChildren().size() == 0){
    31. list.add(p.getId());
    32. return;
    33. }
    34. List children = p.getChildren();
    35. for (Permission per : children){
    36. getCheckKey(per, list);
    37. }
    38. }

    2.3 结果展示

    2.4 查对应的权限菜单(使用中间表)

    2.4.1 后端处理(权限回显)

    使用mybatis-plus生成中间表(rolePermission)

    相对于之前添加了根据角色查询该角色具有的权限id内容

    1. //调中间层
    2. @Autowired
    3. private IRolePermissionService iRolePermissionService;
    4. //自写树结构的获取
    5. @Override
    6. public CommonResult findPermessionByRoleId(String roleId) {
    7. //查询所有的权限
    8. QueryWrapper wrapper=new QueryWrapper<>();
    9. //逻辑删除列考虑在内 还有一个状态列数据库暂未考虑
    10. wrapper.eq("is_deleted",0);
    11. List permissionList = permissionMapper.selectList(wrapper);
    12. //设置层级关系
    13. List firstMenus=new ArrayList<>();
    14. for (Permission first:permissionList) {
    15. //int
    16. if(first.getPid().equals("1")){
    17. firstMenus.add(first);
    18. }
    19. }
    20. //为一级菜单设置二级菜单
    21. for (Permission first : firstMenus) {
    22. //根据一级菜单id 查询 该菜单的二级菜单,如果出现不确定有几级菜单 那么我们可以使用方法的递归调用
    23. first.setChildren(findChildren(permissionList,first.getId()));
    24. }
    25. //根据角色查询该角色具有的权限id
    26. QueryWrapper wrapper1=new QueryWrapper<>();
    27. //根据角色id获得权限
    28. wrapper1.eq("role_id",roleId);
    29. List list = iRolePermissionService.list(wrapper1);
    30. //由集合转换为查询permissionId
    31. List collect = list.stream().map(item -> item.getPermissionId()).distinct().collect(Collectors.toList());
    32. Map map=new HashMap<>();
    33. //treeData为前端要接收的值
    34. map.put("treeData",firstMenus);
    35. map.put("checkIds",collect);
    36. return new CommonResult(2000,"查询成功",map);
    37. }
    38. //方法递归
    39. public void getCheckKey(Permission p,List list){
    40. if(p.getChildren() == null || p.getChildren().size() == 0){
    41. list.add(p.getId());
    42. return;
    43. }
    44. List children = p.getChildren();
    45. for (Permission per : children){
    46. getCheckKey(per, list);
    47. }
    48. }

    2.4.2 前端处理

    1. methods:{
    2. //自写权限点击
    3. permissionClick(row){
    4. this.dialogPerVisible=true;
    5. this.$http.get("/system/permission/findPermessionByRoleId/"+row.id).then(result=>{
    6. this.treeData=result.data.data.treeData;
    7. setTimeout(()=>{
    8. result.data.data.checkIds.forEach(value=>{
    9. this.$refs.rootTree.setChecked(value,true,false);
    10. })
    11. },100)
    12. })
    13. }
    14. }

     点击遮罩层的确定处理

    "primary" @click="confirmFen()">确 定

     添加角色id

    点击确定时

    1. methods:{
    2. //自写权限遮罩层确定
    3. confirmFen(){
    4. //1.获取全选和半选的树 获取对象
    5. var checkedNodes = this.$refs.rootTree.getCheckedNodes(false,true);
    6. //console.log(checkedNodes)
    7. var ids=[];
    8. checkedNodes.forEach(item=>{
    9. ids.push(item.id);
    10. })
    11. //console.log(ids)
    12. this.$http.post("/system/rolePermission/"+this.roleId,ids).then(result=>{
    13. if(result.data.code===2000){
    14. this.dialogPerVisible=false;
    15. this.$message.success("分配权限成功");
    16. }
    17. })
    18. }
    19. }

     console.log打印的结果(第二处ids)

     2.4.3 后端处理(确定修改权限)

    controller层

    1. //自写权限树
    2. @GetMapping("findPermessionByRoleId/{roleId}")
    3. public CommonResult findPermessionByRoleId(@PathVariable String roleId){
    4. return iPermissionService.findPermessionByRoleId(roleId);
    5. }

    serviceImpl层

    1. @Override
    2. @Transactional//事务
    3. public CommonResult fen(String roleId, List ids) {
    4. //删除roleid对应的权限
    5. QueryWrapper wrapper=new QueryWrapper<>();
    6. wrapper.eq("role_id",roleId);
    7. this.remove(wrapper);
    8. //添加
    9. List collect = ids.stream().map(item -> new RolePermission(null, roleId, item, 0, LocalDateTime.now(), LocalDateTime.now())).collect(Collectors.toList());
    10. this.saveBatch(collect);
    11. return new CommonResult(2000,"分配成功",null);
    12. }

    实体类添加

     启动类添加

     

     

     

  • 相关阅读:
    【JavaSE】如何简化Java的异常处理?try-with-resource语句的使用
    SpringBoot学习笔记(三)自动装配
    1000亩盐碱地试验田 国稻种芯-田国庆:拓荒精神荒滩变良田
    每章一篇博客带你拿下吉林大学JAVAEE期末(一)
    uniapp前端微信支付代码
    Thymeleaf将字符串转换为数字
    整理网站页面CV的《长恨歌》文本,python字符串基础知识实战。
    Linux安装redis5.0.14版本详细步骤
    C#创建ini文件写入并读取
    stack容器、queue容器(20221116)
  • 原文地址:https://blog.csdn.net/qq_50896786/article/details/126291477