1、功能
新增用户
修改用户
删除用户
用户列表
用户详情
重置密码
2、数据库表设计
sys_user_info 用户信息表
sys_user_role 用户角色关联表
sys_role_info 角色信息表
用户是在角色下面的
3、流程
(1)新增用户
判断唯一性,看需要哪个字段是唯一的,在插入之前需要先查数据库
添加用户表
添加用户角色表
(2)修改用户
更新用户表
对于用户角色表,可以选择先删除后添加
对用户禁用时,需要将token从redis缓存中去除
(3)删除用户
删除用户角色表(若想保留信息,可添加状态标志,置位即可)
删除用户表(现在用的逻辑删除,将删除标志位置1)
删除用户也需要将token删掉
(4)重置密码
更新用户表密码字段
删除redis中用户密码错误技术计数
4、细节,知识点
(1)对于数据库的新增字段,在代码中所对应的实体、xml映射中都需要添加上
(2)对于代码中的魔法值,需避免,可以写成常量或者枚举类。
对于常量,可以写在常量中,也可以写在配置表中。
package com.gykj.config;
public enum UserStatusEnum {
FORBIDEN(0,"禁用"),
NORMAL(1,"正常");
private Integer key;
private String value;
UserStatusEnum(Integer key, String value) {
this.key = key;
this.value = value;
}
public Integer getKey() {
return key;
}
public void setKey(Integer key) {
this.key = key;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
}
(3)对于入参,有两种,一种是单个单数的,可以加@RequestParam,一种是json形式的,可以加@RequestBody
对于出参,我们都是封装了一个返回包,这需要在接口上添加@ResponseBody,否则接口返回会404
(4)各种数据类型的判空
Byte timestamp的判空只需判null
Byte status;
<if test = "status!=null">
Date modifyTime;
<if test = "modifyTime != null">
5、体会
前期的设计还是非常重要的,要考虑到方方面面。比如重置密码中需要将redis中错误次数删掉。删除用户,禁用启用时将redis中token删掉,让其不让登录。这都是需要积累的
还有就是,多写代码啊!!!熟能生巧,你写的太少了
6、bug修改
1、对于列表查询,记得对前后空格进行trim
2、对于非必填字段,在进行update中,不应把他们放在<if test!=null || test!=''>,不应该判断,直接进行更新
3、对于shiro框架、过滤器的理解又多了些