溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java前后端分離之權(quán)限管理的方法是什么

發(fā)布時(shí)間:2022-08-25 14:10:05 來(lái)源:億速云 閱讀:123 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要講解了“Java前后端分離之權(quán)限管理的方法是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Java前后端分離之權(quán)限管理的方法是什么”吧!

1.前端界面

1.1 按鈕

借助elementui中的表格部分

<template slot-scope="scope">
    <el-button @click="permissionClick(scope.row)" type="primary" size="mini">修改權(quán)限222</el-button>
</template>

1.2 對(duì)話框+樹(shù)形控件

借助elementui中的對(duì)話框和樹(shù)形結(jié)構(gòu)

 <!--自寫(xiě)權(quán)限222-->
        <el-dialog
                title="提示"
                :visible.sync="dialogPerVisible"
                width="30%"
                >
            <!--
                :default-expanded-keys="[2, 3]"默認(rèn)展開(kāi)項(xiàng)
                :default-checked-keys="[5]"默認(rèn)選中項(xiàng)
            -->
            <el-tree
                    :data="treeData"
                    show-checkbox
                    node-key="id"
                    :props="defaultProps">
            </el-tree>
            <span slot="footer" class="dialog-footer">
                <el-button @click="dialogPerVisible = false">取 消</el-button>
                <el-button type="primary" @click="dialogPerVisible = false">確 定</el-button>
            </span>
        </el-dialog>
 data(){
            return{
                //自寫(xiě)權(quán)限樹(shù)遮罩層
                dialogPerVisible:false,
                treeData:[],
                defaultProps: {
                    children: 'children',
                //如果不顯示命名,注意看請(qǐng)求結(jié)果是否為label不是則修改‘label'中的內(nèi)容
                    label: 'label'
                }
            }
        }
methods:{
            //自寫(xiě)權(quán)限點(diǎn)擊
            permissionClick(row){
              this.dialogPerVisible=true;
              this.$http.get("/system/permission/findPermessionByRoleId/"+row.id).then(result=>{
                  this.treeData=result.data.data.treeData;
              })
            }
        }

2.后端操作

2.1 controller層

//自寫(xiě)權(quán)限樹(shù)
    @GetMapping("findPermessionByRoleId/{roleId}")
    public CommonResult findPermessionByRoleId(@PathVariable String roleId){
        return iPermissionService.findPermessionByRoleId(roleId);
    }

2.2 serviceImpl層

此處使用TODO可以在后面進(jìn)行查找此業(yè)務(wù)是否完成

Java前后端分離之權(quán)限管理的方法是什么

 //自寫(xiě)樹(shù)結(jié)構(gòu)的獲取
    @Override
    public CommonResult findPermessionByRoleId(String roleId) {
        //查詢所有的權(quán)限
        QueryWrapper<Permission> wrapper=new QueryWrapper<>();
        //邏輯刪除列考慮在內(nèi) 還有一個(gè)狀態(tài)列數(shù)據(jù)庫(kù)暫未考慮
        wrapper.eq("is_deleted",0);
        List<Permission> permissionList = permissionMapper.selectList(wrapper);
        //設(shè)置層級(jí)關(guān)系
        List<Permission> firstMenus=new ArrayList<>();
        for (Permission first:permissionList) {
            //int
            if(first.getPid().equals("1")){
                firstMenus.add(first);
            }
        }
        //為一級(jí)菜單設(shè)置二級(jí)菜單
        for (Permission first : firstMenus) {
            //根據(jù)一級(jí)菜單id 查詢 該菜單的二級(jí)菜單,如果出現(xiàn)不確定有幾級(jí)菜單 那么我們可以使用方法的遞歸調(diào)用
            first.setChildren(findChildren(permissionList,first.getId()));
        }
        //TODO根據(jù)角色查詢?cè)摻巧哂械臋?quán)限id
        Map<String,Object> map=new HashMap<>();
        //treeData為前端要接收的值
        map.put("treeData",firstMenus);
        return new CommonResult(2000,"查詢成功",map);
    }
    //方法遞歸
    public void getCheckKey(Permission p,List<String> list){
        if(p.getChildren() == null || p.getChildren().size() == 0){
            list.add(p.getId());
            return;
        }
        List<Permission> children = p.getChildren();
        for (Permission per : children){
            getCheckKey(per, list);
        }
    }

2.3 結(jié)果展示

Java前后端分離之權(quán)限管理的方法是什么

Java前后端分離之權(quán)限管理的方法是什么

2.4 查對(duì)應(yīng)的權(quán)限菜單(使用中間表)

2.4.1 后端處理(權(quán)限回顯)

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

相對(duì)于之前添加了根據(jù)角色查詢?cè)摻巧哂械臋?quán)限id內(nèi)容

//調(diào)中間層
    @Autowired
    private IRolePermissionService iRolePermissionService;
    //自寫(xiě)樹(shù)結(jié)構(gòu)的獲取
    @Override
    public CommonResult findPermessionByRoleId(String roleId) {
        //查詢所有的權(quán)限
        QueryWrapper<Permission> wrapper=new QueryWrapper<>();
        //邏輯刪除列考慮在內(nèi) 還有一個(gè)狀態(tài)列數(shù)據(jù)庫(kù)暫未考慮
        wrapper.eq("is_deleted",0);
        List<Permission> permissionList = permissionMapper.selectList(wrapper);
        //設(shè)置層級(jí)關(guān)系
        List<Permission> firstMenus=new ArrayList<>();
        for (Permission first:permissionList) {
            //int
            if(first.getPid().equals("1")){
                firstMenus.add(first);
            }
        }
        //為一級(jí)菜單設(shè)置二級(jí)菜單
        for (Permission first : firstMenus) {
            //根據(jù)一級(jí)菜單id 查詢 該菜單的二級(jí)菜單,如果出現(xiàn)不確定有幾級(jí)菜單 那么我們可以使用方法的遞歸調(diào)用
            first.setChildren(findChildren(permissionList,first.getId()));
        }
        //根據(jù)角色查詢?cè)摻巧哂械臋?quán)限id
        QueryWrapper<RolePermission> wrapper1=new QueryWrapper<>();
        //根據(jù)角色id獲得權(quán)限
        wrapper1.eq("role_id",roleId);
        List<RolePermission> list = iRolePermissionService.list(wrapper1);
        //由集合轉(zhuǎn)換為查詢permissionId
        List<String> collect = list.stream().map(item -> item.getPermissionId()).distinct().collect(Collectors.toList());
        Map<String,Object> map=new HashMap<>();
        //treeData為前端要接收的值
        map.put("treeData",firstMenus);
        map.put("checkIds",collect);
        return new CommonResult(2000,"查詢成功",map);
    }
    //方法遞歸
    public void getCheckKey(Permission p,List<String> list){
        if(p.getChildren() == null || p.getChildren().size() == 0){
            list.add(p.getId());
            return;
        }
        List<Permission> children = p.getChildren();
        for (Permission per : children){
            getCheckKey(per, list);
        }
    }
2.4.2 前端處理

Java前后端分離之權(quán)限管理的方法是什么

methods:{
            //自寫(xiě)權(quán)限點(diǎn)擊
            permissionClick(row){
              this.dialogPerVisible=true;
              this.$http.get("/system/permission/findPermessionByRoleId/"+row.id).then(result=>{
                  this.treeData=result.data.data.treeData;
                  setTimeout(()=>{
                      result.data.data.checkIds.forEach(value=>{
                          this.$refs.rootTree.setChecked(value,true,false);
                      })
                  },100)
              })
            }
}

點(diǎn)擊遮罩層的確定處理

<el-button type="primary" @click="confirmFen()">確 定</el-button>

添加角色id

Java前后端分離之權(quán)限管理的方法是什么

點(diǎn)擊確定時(shí)

 methods:{
            //自寫(xiě)權(quán)限遮罩層確定
            confirmFen(){
                //1.獲取全選和半選的樹(shù) 獲取對(duì)象
               var checkedNodes = this.$refs.rootTree.getCheckedNodes(false,true);
               //console.log(checkedNodes)
                var ids=[];
                checkedNodes.forEach(item=>{
                    ids.push(item.id);
                })
                //console.log(ids)
                this.$http.post("/system/rolePermission/"+this.roleId,ids).then(result=>{
                    if(result.data.code===2000){
                        this.dialogPerVisible=false;
                        this.$message.success("分配權(quán)限成功");
                    }
                })
            }
}

console.log打印的結(jié)果(第二處ids)

Java前后端分離之權(quán)限管理的方法是什么

2.4.3 后端處理(確定修改權(quán)限)

controller層

//自寫(xiě)權(quán)限樹(shù)
    @GetMapping("findPermessionByRoleId/{roleId}")
    public CommonResult findPermessionByRoleId(@PathVariable String roleId){
        return iPermissionService.findPermessionByRoleId(roleId);
    }

serviceImpl層

 @Override
    @Transactional//事務(wù)
    public CommonResult fen(String roleId, List<String> ids) {
        //刪除roleid對(duì)應(yīng)的權(quán)限
        QueryWrapper<RolePermission> wrapper=new QueryWrapper<>();
        wrapper.eq("role_id",roleId);
        this.remove(wrapper);
        //添加
        List<RolePermission> collect = ids.stream().map(item -> new RolePermission(null, roleId, item, 0, LocalDateTime.now(), LocalDateTime.now())).collect(Collectors.toList());
        this.saveBatch(collect);
        return new CommonResult(2000,"分配成功",null);
    }

實(shí)體類添加

Java前后端分離之權(quán)限管理的方法是什么

啟動(dòng)類添加

Java前后端分離之權(quán)限管理的方法是什么

感謝各位的閱讀,以上就是“Java前后端分離之權(quán)限管理的方法是什么”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Java前后端分離之權(quán)限管理的方法是什么這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI