1.说明

只讲解关键部分,详细看源码,文章下方捐赠或QQ联系捐赠获取。

2.功能展示


3.业务模型

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("sys_role")
public class SysRole implements Serializable { private static final long serialVersionUID = 1L; /**
* 角色id
*/
@TableId(value = "id", type = IdType.AUTO)
private Integer id; /**
* 角色名称
*/
private String roleName; /**
* 角色编码
*/
private String roleCode; /**
* 创建时间
*/
@TableField(fill = FieldFill.INSERT)
private Date createTime; /**
* 创建人
*/
private String createUser; /**
* 修改时间
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime; /**
* 修改人
*/
private String updateUser; @TableField(exist=false)
private String deptName; @TableField(exist=false)
private List<SysUser> userList; @TableField(exist=false)
private boolean checked; }

4.控制器

@Controller
@RequestMapping("/sysRole")
public class SysRoleController {
@Autowired
private SysRoleService roleService; @Autowired
private SysMenuService menuService; @Autowired
private SysRoleUserService roleUserService; @GetMapping("listUI")
public String listUI() {
return "role/list";
} @GetMapping("selectMenu/{id}")
public String selectMenu(@PathVariable Integer id, Map<String,Object> map) {
SysRole role = roleService.getById(id);
map.put("role", role);
return "role/selectMenu";
} @PostMapping("list")
@ResponseBody
public Result<IPage<SysRole>> list(@RequestParam(defaultValue = "1") Integer pageNo,
@RequestParam(defaultValue = "10") Integer pageSize) {
QueryWrapper<SysRole> queryWrapper = new QueryWrapper<>();
Page<SysRole> page = new Page<>(pageNo,pageSize);
IPage<SysRole> result = roleService.selectRoleList(page, null);
// 设置总记录数
result.setTotal(roleService.count(queryWrapper)); /*Pager pager = JsonUtil.getObjectFromJson(gridPager, Pager.class);
Map<String, Object> parameters = null;
if(Validator.isNullOrEmpty(pager.getParameters())){
parameters = new HashMap<>();
}else{
parameters = pager.getParameters();
}
Integer deptId = getUserEntity().getDeptId();
if(Validator.isNotNullOrEmpty(parameters.get("deptId"))){
deptId = Integer.parseInt(parameters.get("deptId").toString());
}
Page<SysRole> list = roleService.selectRoleList(new Page<SysRole>(pager.getNowPage(), pager.getPageSize()),deptId);
makeGridResult(parameters, pager, list);*/
return ResultUtil.ok(result);
} @GetMapping("form")
public String form(Map<String,Object> map) {
return "role/form";
} @OperLog(operModule = "用户管理",operType = "修改",operDesc = "修改角色")
@PostMapping("save")
@ResponseBody
public Result<String> add(@RequestBody SysRole role){
if(role.getId()==null){
role.setCreateTime(new Date(System.currentTimeMillis()));
role.setUpdateTime(new Date(System.currentTimeMillis()));
}else
{
role.setUpdateTime(new Date(System.currentTimeMillis()));
} if(!roleService.saveOrUpdate(role)){
return ResultUtil.fail("保存失败!");
}
return ResultUtil.ok();
} @OperLog(operModule = "角色管理",operType = "删除",operDesc = "删除角色")
@PostMapping("/remove")
@ResponseBody
public Result<String> remove(@RequestParam Integer id) {
// 判断该角色下是否有用户
QueryWrapper<SysRoleUser> roleUserQuery = new QueryWrapper<>();
roleUserQuery.eq("role_id",id);
int roleUserCount = roleUserService.count(roleUserQuery);
if(roleUserCount > 0){
return ResultUtil.fail("该角色下存在用户!");
} // 先删除角色和权限关系记录
roleService.deleteRoleMenu(id);
// 删除角色记录
roleService.removeById(id); return ResultUtil.ok();
} /**
* 根据角色ID查询角色
* @param map
* @param roleId
* @return
*/
@GetMapping("{roleId}/select")
public String select(Map<String,Object> map,@PathVariable(required=true) Integer roleId) {
SysRole role = roleService.getById(roleId);
map.put("role", role);
return "role/edit";
} @GetMapping("{roleId}/menu")
public String permission(Map<String,Object> map,@PathVariable(required=true) Integer roleId) {
SysRole role = roleService.getById(roleId);
List<SysMenu> resources = menuService.queryMenuList(ConvertUtil.toMap("roleId",(Object)roleId));
List<JSTreeEntity> jstreeList = new TreeUtil().generateJSTree(resources);
map.put("role", role);
map.put("menus", jstreeList);
return "role/menu";
} /**
* 根据角色ID查询角色拥有的菜单权限
* @param roleId
* @return
*/
@GetMapping("/getMenu/{roleId}")
@ResponseBody
public List<SysMenu> getMenu(@PathVariable(required=true) Integer roleId) {
List<SysMenu> menus = menuService.queryMenuList(ConvertUtil.toMap("roleId",(Object)roleId));
return menus;
} @OperLog(operModule = "角色管理",operType = "修改",operDesc = "分配权限")
@PostMapping("saveMenu")
@ResponseBody
public Result<String> saveMenu(Integer roleId, @RequestParam(value = "menuIds[]") Integer[] menuIds){
roleService.saveMenu(roleId, Arrays.asList(menuIds));
return ResultUtil.ok();
} @GetMapping("listAll")
@ResponseBody
public List<SysRole> listAll(){
List<SysRole> sysRoles = roleService.selectRoleList(null);
/*List<SelectEntity> selectList = new ArrayList<>();
SelectEntity entity = null;
for (SysRole role: sysRoles
) {
entity = new SelectEntity();
entity.setId(role.getId());
entity.setName(role.getRoleName());
selectList.add(entity);
}*/ return sysRoles;
}
}

5.前端页面

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
<meta charset="utf-8">
<title>角色列表</title>
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<link rel="stylesheet" th:href="@{/static/plugin/layui/css/layui.css}" media="all">
</head>
<body>
<table class="layui-hide" id="SysRole" lay-filter="SysRole"></table> <input type="text" id="ctx" hidden="hidden" th:value="${#request.getContextPath()}"> <!--编辑表单-->
<div class="layui-row" id="editForm" style="display:none;">
<div class="layui-col-md10">
<form class="layui-form layui-from-pane" action="" style="margin-top:20px">
<input type="text" id="id" name="id" hidden="hidden">
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label">角色名称</label>
<div class="layui-input-inline">
<input type="text" id="roleName" name="roleName" required lay-verify="required" autocomplete="off"
placeholder="" class="layui-input">
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label">角色编码</label>
<div class="layui-input-inline">
<input type="text" id="roleCode" name="roleCode" required lay-verify="required" autocomplete="off"
placeholder="" class="layui-input">
</div>
</div>
</div>
<div class="layui-form-item" style="margin-top:40px">
<div class="layui-input-block">
<button class="layui-btn layui-btn-submit " lay-submit="" lay-filter="confirm">确认</button>
<button type="button" class="layui-btn layui-btn-primary" id="closeBtn">关闭</button>
</div>
</div>
</form>
</div>
</div> <script type="text/html" id="roleToolBar">
<div class="layui-btn-container">
<button class="layui-btn layui-btn-sm" lay-event="add" shiro:hasPermission="role:add">新增</button>
<button class="layui-btn layui-btn-sm" lay-event="addMenu" shiro:hasPermission="role:addMenu">分配权限</button>
</div>
</script>

6 获取源码

捐赠任意金额,评论区留下邮箱发送 :)

SpringBoot+Shiro+LayUI权限管理系统项目-6.实现角色管理的更多相关文章

  1. 基于easyUI实现权限管理系统(三)——角色管理

    此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. 相关文件介绍 1. role.jsp:角色管理界面 <!DOCTYPE html PUBLIC "-//W3 ...

  2. SpringBoot框架的权限管理系统

    springBoot框架的权限管理系统,支持操作权限和数据权限,后端采用springBoot,MyBatis,Shiro,前端使用adminLTE,Vue.js,bootstrap-table.tre ...

  3. SpringBoot&Shiro实现权限管理

    SpringBoot&Shiro实现权限管理 引言 相信大家前来看这篇文章的时候,是有SpringBoot和Shiro基础的,所以本文只介绍整合的步骤,如果哪里写的不好,恳请大家能指出错误,谢 ...

  4. Asp.Net Core 项目实战之权限管理系统(6) 功能管理

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  5. SpringBoot+Shiro学习(七):Filter过滤器管理

    SpringBoot+Shiro学习(七):Filter过滤器管理 Hiwayz 关注  0.5 2018.09.06 19:09* 字数 1070 阅读 5922评论 1喜欢 20 先从我们写的一个 ...

  6. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(27)-权限管理系统-分配用户给角色

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(27)-权限管理系统-分配用户给角色 分配用户给角色,跟分配角色给用户操作是基本一致的. 打开模块维护,展 ...

  7. spring boot + mybatis + layui + shiro后台权限管理系统

    后台管理系统 版本更新 后续版本更新内容 链接入口: springboot + shiro之登录人数限制.登录判断重定向.session时间设置:https://blog.51cto.com/wyai ...

  8. niaobulashi-一个基于springboot shrio的权限管理系统

    github项目地址:https://github.com/niaobulashi/niaobulashi springboot学习地址:http://www.ityouknow.com/spring ...

  9. .NET Core/.NET5/.NET6 开源项目汇总5:权限管理系统项目

    系列目录     [已更新最新开发文章,点击查看详细] 企业管理系统一般包含后台管理UI.组织机构管理.权限管理.日志.数据访问.表单.工作流等常用必备功能.下面收集的几款优秀开源的管理系统,值得大家 ...

  10. (一)shiro简介和用户登录demo及角色管理

    一.shiro简介 Apache Shiro是Java的一个安全框架.Shiro可以非常容易的开发出足够好的应用,其不仅可以用在JavaSE环境,也可以用在JavaEE环境.Shiro可以帮助我们完成 ...

随机推荐

  1. CAP-BASE

  2. 【秘籍揭秘】如何高速下载游戏、Switch资源?省时省力一网打尽!

    百度云盘SVIP合租啦亲爱的考研党和游戏玩家们,我今天要分享的是一份独家秘籍!你是不是常常为下载游戏或Switch资源而烦恼?是不是经常遇到下载速度慢.限速等问题,让你等待无尽?别担心,我有一个绝密的 ...

  3. [转帖]jdbc连接mysql设置session variables 参数变量

    目录 两种方式 连接串设置[^1] 执行语句中设置 两种方式 url连接串中设置 执行语句中设置 连接串设置1 sessionVariables jdbc.url=jdbc:mysql://xxxx. ...

  4. [转帖]TIDB - TIDB集群的扩容和缩容及TIUP指令说明

    一.TIUP工具简介 前面介绍了使用TIUP搭建TIDB集群,本篇文章详细介绍下使用TIUP对集群进行扩容和缩容. 在面对双十一这种流量突峰的场景,我们平常的TIDB集群有可能承受不住,因此需要提前进 ...

  5. [换帖]Linux命令之iconv命令

    一.命令简介   日常工作中我们需要将windows生成的文件上传到Linux系统,有时候会因为编码问题出现显示乱码.例如我上传了一个csv文件到Linux服务器上,默认编码为GB2312,在Linu ...

  6. dd命令的简单学习

    dd命令简介 dd Copy a file, converting and formatting according to the operands. dd 可以理解为是 disk dump 磁盘转储 ...

  7. 不同信创服务器Redis7.0.5性能表现总结

    不同信创服务器Redis7.0.5性能表现总结 背景以及基础约定 随着美帝2022.10收紧EAR规定的硬件出口规定 信创事业迎来了一波新的高潮. 最近不仅仅要求国产化的硬件. 更要求国产化的OS,以 ...

  8. JS中every的简单使用

    every 方法 every()方法用于检测数组中的所有元素是否都满足指定条件. every()方法会遍历数组的每一项,如果有一项不满足条件,则返回false,剩余的项将不会再执行检测. 如果遍历完数 ...

  9. flask session 伪造

    flask session 伪造 一.session的作用 由于http协议是一个无状态的协议,也就是说同一个用户第一次请求和第二次请求是完全没有关系的,但是现在的网站基本上有登录使用的功能,这就要求 ...

  10. CLion搭建Qt开发环境,并解决目录重构问题(最新版)

    序言 Qt版本不断更新,QtCreator也不断更新.在Qt4和Qt5时代,我一直认为开发Qt最好的IDE就是自带的QtCreator,可是时至今日,到了Qt6时代,QtCreator已经都12.0. ...