SpringBoot+Shiro+LayUI权限管理系统项目-7.实现用户管理
1.说明
只讲解关键部分,详细看源码,文章下方捐赠或QQ联系捐赠获取。
2.功能展示
包括用户增删改查和分配角色。


3.业务模型
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("sys_user")
public class SysUser implements Serializable {
private static final long serialVersionUID = 1L;
/**
* id
*/
@TableId(value = "id", type = IdType.AUTO)
private Integer id;
/**
* 用户名
*/
private String username;
/**
* 用户密码
*/
private String password;
/**
* 真实姓名
*/
private String truename;
/**
* 邮箱
*/
private String email;
/**
* 电话
*/
private String phone;
/**
* 所属部门ID
*/
private Integer deptId;
/**
* 头像地址
*/
//private String avatar;
/**
* 创建时间
*/
@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 SysRole role;
@TableField(exist=false)
private SysDept dept;
}
4.控制器
@Controller
@RequestMapping("/sysUser")
public class SysUserController {
@Autowired
private SysUserService userService;
@Autowired
private SysRoleService roleService;
@Autowired
private SysDeptService deptService;
@Autowired
private SysRoleUserService roleUserService;
@GetMapping("listUI")
public String listUI() {
return "user/list";
}
@GetMapping("toSelectDept")
public String SelectDept() {
return "user/selectDept";
}
@GetMapping("selectRole/{userId}")
public String SelectRole(@PathVariable Integer userId, Model model) {
// 根据用户ID查询其拥有的角色
//List<Map<String,Object>> roles = userService.selectRolesByUserId(userId);
SysUser entity = userService.getById(userId);
model.addAttribute("user", entity);
return "user/selectRole";
}
@PostMapping("list")
@ResponseBody
public Result<IPage<SysUser>> list(@RequestParam(value = "username", required = false) String username,
@RequestParam(value = "deptId", required = false) Integer deptId,
@RequestParam(defaultValue = "1") Integer pageNo,
@RequestParam(defaultValue = "10") Integer pageSize) {
// 获取当前已登录用户部门ID
/*Integer currentDeptId = getUserEntity().getDeptId();
if(deptId==null){
deptId = currentDeptId;
}*/
QueryWrapper<SysUser> queryWrapper = new QueryWrapper<>();
Page<SysUser> page = new Page<>(pageNo,pageSize);
IPage<SysUser> result = userService.selectUserList(page, username, deptId);
// 设置总记录数
result.setTotal(userService.count(queryWrapper));
return ResultUtil.ok(result);
}
@GetMapping("checkAccount")
@ResponseBody
public boolean checkAccount(@RequestParam(required=true) String username) {
List<SysUser> user = (List<SysUser>) userService.listByMap(ConvertUtil.toMap("username",(Object)username));
if(!Validator.isNullOrEmpty(user)){
return false;
}
return true;
}
@OperLog(operModule = "用户管理",operType = "修改",operDesc = "修改用户")
@PostMapping("save")
@ResponseBody
public Result<String> add(@RequestBody SysUser user, Map<String,Object> map){
if(user.getId()==null){
// 检查用户是否存在
if(!checkAccount(user.getUsername())){
return ResultUtil.fail("用户名已存在!");
}
// 设置添加用户的密码和加密盐
user.setPassword(MD5Util.md5Password(user.getPassword(),2));
//user.setSalt(userEntity.getSalt());
// 设置创建者姓名
user.setCreateUser("");
user.setCreateTime(new Date());
// 保存用户
boolean result = userService.save(user);
if(!result)
{
return ResultUtil.fail("添加失败!");
}
// 添加角色和用户关系记录
/*SysRoleUser roleUser = new SysRoleUser();
roleUser.setRoleId(user.getRole().getId());
roleUser.setUserId(user.getId());
roleUserService.save(roleUser);*/
}else{
user.setUpdateTime(new Date());
userService.saveOrUpdate(user);
}
return ResultUtil.ok();
}
@OperLog(operModule = "用户管理",operType = "删除",operDesc = "删除用户")
@PostMapping("remove")
@ResponseBody
public Result<String> remove(@RequestParam Integer id) {
// 1.删除用户与角色的关联记录
Map<String,Object> param = new HashMap<>();
param.put("user_id", id);
roleUserService.removeByMap(param);
// 2.删除用户
if(!userService.removeById(id)){
return ResultUtil.fail("删除失败!");
}
return ResultUtil.ok();
}
@GetMapping("info/{userId}")
public String selectInfo(Map<String,Object> map,@PathVariable(required=true) Integer userId) {
SysUser user = userService.getById(userId);
map.put("user", user);
return "user/info";
}
// 根据用户Id查询其拥有的角色
@GetMapping("/getRoles/{userId}")
@ResponseBody
public List<SysRole> getRoles(@PathVariable Integer userId){
List<SysRole> roles = userService.selectRolesByUserId(userId);
return roles;
}
// 保存用户角色
@OperLog(operModule = "用户管理",operType = "修改",operDesc = "分配角色")
@PostMapping("saveRole")
@ResponseBody
public Result<String> saveRole(@RequestParam Integer userId, @RequestParam(value = "roleIds[]") Integer[] roleIds){
userService.saveRole(userId, Arrays.asList(roleIds));
return ResultUtil.ok();
}
}
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>
<div class="searchTable">
用户名:
<div class="layui-inline">
<input class="layui-input" name="s_username" id="s_username" autocomplete="off">
</div>
<button id="searchBtn" class="layui-btn" data-type="reload">搜索</button>
</div>
<table class="layui-hide" id="SysUser" lay-filter="SysUser"></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-line" style="float: left;">
<input type="text" id="deptName" name="deptName" required lay-verify="required" autocomplete="off"
class="layui-input" disabled="disabled">
</div>
<button class="layui-btn layui-btn-sm" id="chooseDept" type="button" style="float: left;margin-left: 1.5em;">
<i class="layui-icon"></i>
</button>
<input type="hidden" id="deptId" name="deptId"/>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">用户名</label>
<div class="layui-input-block">
<input type="text" id="username" name="username" required lay-verify="required" autocomplete="off"
placeholder="" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">密码</label>
<div class="layui-input-block">
<input type="password" id="password" name="password" required lay-verify="required"
autocomplete="off"
placeholder="" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">姓名</label>
<div class="layui-input-block">
<input type="text" id="truename" name="truename" required lay-verify="required" autocomplete="off"
placeholder="" class="layui-input">
</div>
</div>
<!--<div class="layui-form-item">
<label class="layui-form-label">角色</label>
<div class="layui-input-block">
<select id="roleId" name="roleId" lay-verify="required">
<option value=""></option>
</select>
<div class="layui-unselect layui-form-select">
<div class="layui-select-title">
<input type="text" placeholder="请选择" value="" readonly=""
class="layui-input layui-unselect">
<i class="layui-edge"></i>
</div>
</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="back">关闭</button>
</div>
</div>
</form>
</div>
</div>
6 获取源码
捐赠任意金额,评论区留下邮箱发送 :)

SpringBoot+Shiro+LayUI权限管理系统项目-7.实现用户管理的更多相关文章
- 基于easyUI实现权限管理系统(四)——用户管理
此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. 相关文件介绍 1. user.jsp:用户管理界面 <!DOCTYPE html PUBLIC "-//W3 ...
- SpringBoot框架的权限管理系统
springBoot框架的权限管理系统,支持操作权限和数据权限,后端采用springBoot,MyBatis,Shiro,前端使用adminLTE,Vue.js,bootstrap-table.tre ...
- SpringBoot&Shiro实现权限管理
SpringBoot&Shiro实现权限管理 引言 相信大家前来看这篇文章的时候,是有SpringBoot和Shiro基础的,所以本文只介绍整合的步骤,如果哪里写的不好,恳请大家能指出错误,谢 ...
- .NET Core/.NET5/.NET6 开源项目汇总5:权限管理系统项目
系列目录 [已更新最新开发文章,点击查看详细] 企业管理系统一般包含后台管理UI.组织机构管理.权限管理.日志.数据访问.表单.工作流等常用必备功能.下面收集的几款优秀开源的管理系统,值得大家 ...
- Asp.Net Core 项目实战之权限管理系统(5) 用户登录
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- Asp.Net Core 项目实战之权限管理系统(6) 功能管理
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- SpringBoot+Shiro学习(七):Filter过滤器管理
SpringBoot+Shiro学习(七):Filter过滤器管理 Hiwayz 关注 0.5 2018.09.06 19:09* 字数 1070 阅读 5922评论 1喜欢 20 先从我们写的一个 ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户
原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x ...
- spring boot + mybatis + layui + shiro后台权限管理系统
后台管理系统 版本更新 后续版本更新内容 链接入口: springboot + shiro之登录人数限制.登录判断重定向.session时间设置:https://blog.51cto.com/wyai ...
- niaobulashi-一个基于springboot shrio的权限管理系统
github项目地址:https://github.com/niaobulashi/niaobulashi springboot学习地址:http://www.ityouknow.com/spring ...
随机推荐
- python环境 anaconda安装
官网: https://www.anaconda.com/distribution/#macos 国内镜像: https://mirrors.tuna.tsinghua.edu.cn/anaconda ...
- [转帖]shell编程:变量知识进阶(三)
https://www.cnblogs.com/luoahong/articles/9154309.html 1 Shell特殊位置变量 范例1:$n的实践例子 1 2 3 4 5 6 7 8 9 1 ...
- [转帖]tidb之旅——tidb架构选择
https://zhuanlan.zhihu.com/p/641650168 前言 从4月份开始利用tidb改造了我们公司bi系统.这个过程中,我感觉到了tidb的强大.也打算记录一下整个改造过程.我 ...
- [转帖]KingbaseES不同字符类型比较转换规则
https://www.cnblogs.com/kingbase/p/14798059.html Postgresql 常用的字符数据类型的有char.varchar和text,其中 char 固定长 ...
- [转帖]CentOS7上systemctl的使用
https://www.cnblogs.com/yeyuzhuanjia/p/14676182.html CentOS 7.x开始,CentOS开始使用systemd服务来代替daemon,原来管理系 ...
- [转帖]linux下 进程io队列,IO队列和IO调度
IO体系概览 先看看本文主题IO调度和IO队列处于整个IO体系的哪个位置,这个IO体系是非常重要的,了解IO体系我们可以对整个IO过程有个全面的认识.虽然一下两下并不清楚IO体系各个部分的细节,但是我 ...
- Redis Cluster in K3S
Redis Cluster in K3S 学习资料 https://www.cnblogs.com/cheyunhua/p/15619317.html https://blog.csdn.net/cq ...
- SUBMIT指定用户名错误
1.SUBMIT说明 在ABAP中,SUBMIT关键字用于运行另一个ABAP程序.通过SUBMIT关键字,可以在当前程序内部调用其他程序,而无需关闭当前程序. SUBMIT语句的一般语法如下: &qu ...
- HBase深度历险 | 京东物流技术团队
简介 HBase 的全称是 Hadoop Database,是一个分布式的,可扩展,面向列簇的数据库,是一个通过大量廉价的机器解决海量数据的高速存储和读取的分布式数据库解决方案.本文会像剥洋葱一样,层 ...
- 使用Visual Studio调试 .NET源代码
前言 在我们日常开发过程中常常会使用到很多其他封装好的第三方类库(NuGet依赖项)或者是.NET框架中自带的库.如果可以设置断点并在NuGet依赖项或框架本身上使用调试器的所有功能,那么我们的源码调 ...