SSM项目添加权限控制(接上水文)

接上:
https://blog.csdn.net/qq_43923042/article/details/107561103
准备:新建两个表
在这里插入图片描述

1.首先添加两个bean类Role和UserRole
在这里插入图片描述
在这里插入图片描述
2.编写dao层接口
在这里插入图片描述
3.编写mapper配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.zhongruan.dao.RoleDao" >
    <select id="findRoleIdByUserId" parameterType="int" resultType="int">
        select roleId from xiaolaji_role_user where userId=#{id}
    </select>
    <select id="findRoleByUserId" parameterType="int" resultType="role">
        select * from xiaolaji_role where id not in(select roleId from xiaolaji_role_user where userId=#{id})
    </select>
    <insert id="addRole" parameterType="role">
        insert into xiaolaji_Role(rolename,roledesc)
         values (#{rolename},#{roledesc});
    </insert>
</mapper>

4.完成service层的编写

package com.zhongruan.service.Impl;
import com.zhongruan.beans.Role;
import com.zhongruan.beans.UserRole;
import com.zhongruan.dao.RoleDao;
import com.zhongruan.service.RoleService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import javax.xml.ws.ServiceMode;
import java.util.List;
@Service
public class RoleServiceImpl implements RoleService {
    @Autowired
    private RoleDao roleDao;
    @Override
    public List<Integer> findRoleId(int userId) {
        return roleDao.findRoleIdByUserId(userId);
    }
    @Override
    public List<Role> findRoleByUserId(int id) {
        return roleDao.findRoleByUserId(id);
    }
    @Override
    public void add(List<Integer> ids, String userId) {
        for (int roleId:ids){
            UserRole userRole=new UserRole();
            userRole.setUserId(Integer.parseInt(userId));
            userRole.setRoleId(roleId);
            roleDao.addRole(userRole);
        }
    }
}

5.完善Controller层:

@RequestMapping("toAddRole.do")
    public ModelAndView toAddRole(int id){
        List<Role> roleList=roleService.findRoleByUserId(id);
        ModelAndView mv=new ModelAndView();
        mv.addObject("roles",roleList);
        mv.addObject("id",id);
        mv.setViewName("user-role-add");
        return mv;
    }

    @RequestMapping("addRole.do")
    @ResponseBody
    public String add(String roleList,String userId){
        System.out.println("roleList---:"+roleList);
        System.out.println("userId---:"+userId);
        String[] strs=roleList.split(",");
        List<Integer> ids=new ArrayList<>();
        for (String i:strs){
            ids.add(Integer.parseInt(i));
        }
        roleService.add(ids,userId);
        return "toAddRole.do";
    }

配置结果:
在这里插入图片描述
点击添加角色后会出现以下画面:
在这里插入图片描述
SSM项目算是结束了,下面为SSM项目建立的大致流程
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值