diff --git a/sql/ry_20180524.sql b/sql/ry_20180524.sql
index 4b271687d..642adb09c 100644
--- a/sql/ry_20180524.sql
+++ b/sql/ry_20180524.sql
@@ -48,23 +48,22 @@ create table sys_user (
avatar varchar(100) default '' comment '头像路径',
password varchar(100) default '' comment '密码',
salt varchar(100) default '' comment '盐加密',
- user_type char(1) default 'N' comment '类型:Y默认用户,N非默认用户',
- status int(1) default 0 comment '帐号状态:0正常,1禁用',
- refuse_des varchar(500) default '' comment '拒绝登录描述',
+ status int(1) default 0 comment '帐号状态(0正常 1禁用 2删除)',
login_ip varchar(100) default '' comment '最后登陆IP',
login_date datetime comment '最后登陆时间',
create_by varchar(64) default '' comment '创建者',
create_time datetime comment '创建时间',
update_by varchar(64) default '' comment '更新者',
update_time datetime comment '更新时间',
+ remark varchar(500) default '' comment '备注',
primary key (user_id)
) engine=innodb auto_increment=100 default charset=utf8 comment = '用户信息表';
-- ----------------------------
-- 初始化-用户信息表数据
-- ----------------------------
-insert into sys_user values(1, 106, 'admin', '若依', 'ry@163.com', '15888888888', '1', '', '29c67a30398638269fe600f73a054934', '111111', 'Y', 0, '正常', '127.0.0.1', '2018-03-16 11-33-00', 'admin', '2018-03-16 11-33-00', 'ry', '2018-03-16 11-33-00');
-insert into sys_user values(2, 108, 'ry', '若依', 'ry@qq.com', '15666666666', '1', '', '8e6d98b90472783cc73c17047ddccf36', '222222', 'N', 0, '正常', '127.0.0.1', '2018-03-16 11-33-00', 'admin', '2018-03-16 11-33-00', 'ry', '2018-03-16 11-33-00');
+insert into sys_user values(1, 106, 'admin', '若依', 'ry@163.com', '15888888888', '1', '', '29c67a30398638269fe600f73a054934', '111111', 0, '127.0.0.1', '2018-03-16 11-33-00', 'admin', '2018-03-16 11-33-00', 'ry', '2018-03-16 11-33-00', '管理员');
+insert into sys_user values(2, 108, 'ry', '若依', 'ry@qq.com', '15666666666', '1', '', '8e6d98b90472783cc73c17047ddccf36', '222222', 0, '127.0.0.1', '2018-03-16 11-33-00', 'admin', '2018-03-16 11-33-00', 'ry', '2018-03-16 11-33-00', '测试员');
-- ----------------------------
-- 3、岗位信息表
diff --git a/src/main/java/com/ruoyi/framework/shiro/service/LoginService.java b/src/main/java/com/ruoyi/framework/shiro/service/LoginService.java
index e5aba6184..0997a9e71 100644
--- a/src/main/java/com/ruoyi/framework/shiro/service/LoginService.java
+++ b/src/main/java/com/ruoyi/framework/shiro/service/LoginService.java
@@ -16,6 +16,7 @@ import com.ruoyi.common.utils.ServletUtils;
import com.ruoyi.common.utils.SystemLogUtils;
import com.ruoyi.common.utils.security.ShiroUtils;
import com.ruoyi.project.system.user.domain.User;
+import com.ruoyi.project.system.user.domain.UserStatus;
import com.ruoyi.project.system.user.service.IUserService;
/**
@@ -78,7 +79,7 @@ public class LoginService
user = userService.selectUserByEmail(username);
}
- if (user == null)
+ if (user == null || UserStatus.DELETED.getCode() == user.getStatus())
{
SystemLogUtils.log(username, CommonConstant.LOGIN_FAIL, MessageUtils.message("user.not.exists"));
throw new UserNotExistsException();
@@ -86,10 +87,10 @@ public class LoginService
passwordService.validate(user, password);
- if (UserConstants.USER_BLOCKED == user.getStatus())
+ if (UserStatus.DISABLE.getCode() == user.getStatus())
{
- SystemLogUtils.log(username, CommonConstant.LOGIN_FAIL, MessageUtils.message("user.blocked", user.getRefuseDes()));
- throw new UserBlockedException(user.getRefuseDes());
+ SystemLogUtils.log(username, CommonConstant.LOGIN_FAIL, MessageUtils.message("user.blocked", user.getRemark()));
+ throw new UserBlockedException(user.getRemark());
}
SystemLogUtils.log(username, CommonConstant.LOGIN_SUCCESS, MessageUtils.message("user.login.success"));
recordLoginInfo(user);
diff --git a/src/main/java/com/ruoyi/project/system/user/controller/UserController.java b/src/main/java/com/ruoyi/project/system/user/controller/UserController.java
index 756fefb79..639bcfb2c 100644
--- a/src/main/java/com/ruoyi/project/system/user/controller/UserController.java
+++ b/src/main/java/com/ruoyi/project/system/user/controller/UserController.java
@@ -12,6 +12,8 @@ import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
+
+import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.framework.aspectj.lang.annotation.Log;
import com.ruoyi.framework.web.controller.BaseController;
import com.ruoyi.framework.web.domain.Message;
@@ -21,6 +23,7 @@ import com.ruoyi.project.system.post.service.IPostService;
import com.ruoyi.project.system.role.domain.Role;
import com.ruoyi.project.system.role.service.IRoleService;
import com.ruoyi.project.system.user.domain.User;
+import com.ruoyi.project.system.user.domain.UserStatus;
import com.ruoyi.project.system.user.service.IUserService;
/**
@@ -129,11 +132,12 @@ public class UserController extends BaseController
{
return Message.error("用户不存在");
}
- if (userService.deleteUserById(userId) > 0)
+ else if (User.isAdmin(userId))
{
- return Message.success();
+ return Message.error("不允许删除超级管理员用户");
}
- return Message.error();
+ user.setStatus(UserStatus.DELETED.getCode());
+ return userService.updateUser(user) > 0 ? Message.success() : Message.error();
}
@RequiresPermissions("system:user:batchRemove")
@@ -161,11 +165,11 @@ public class UserController extends BaseController
@ResponseBody
public Message save(User user)
{
- if (userService.saveUser(user) > 0)
+ if (StringUtils.isNotNull(user.getUserId()) && User.isAdmin(user.getUserId()))
{
- return Message.success();
+ return Message.error("不允许修改超级管理员用户");
}
- return Message.error();
+ return userService.saveUser(user) > 0 ? Message.success() : Message.error();
}
/**
@@ -183,7 +187,6 @@ public class UserController extends BaseController
return uniqueFlag;
}
-
/**
* 校验手机号码
*/
diff --git a/src/main/java/com/ruoyi/project/system/user/domain/User.java b/src/main/java/com/ruoyi/project/system/user/domain/User.java
index 902928a9c..e0b98f8be 100644
--- a/src/main/java/com/ruoyi/project/system/user/domain/User.java
+++ b/src/main/java/com/ruoyi/project/system/user/domain/User.java
@@ -36,12 +36,8 @@ public class User extends BaseEntity
private String password;
/** 盐加密 */
private String salt;
- /** 类型:Y默认用户,N非默认用户 */
- private String userType;
- /** 帐号状态:0正常,1禁用 */
+ /** 帐号状态:0正常,1禁用,2删除 */
private int status;
- /** 拒绝登录描述 */
- private String refuseDes;
/** 最后登陆IP */
private String loginIp;
/** 最后登陆时间 */
@@ -63,6 +59,16 @@ public class User extends BaseEntity
this.userId = userId;
}
+ public boolean isAdmin()
+ {
+ return isAdmin(this.userId);
+ }
+
+ public static boolean isAdmin(Long userId)
+ {
+ return userId != null && 1L == userId;
+ }
+
public Long getDeptId()
{
return deptId;
@@ -174,16 +180,6 @@ public class User extends BaseEntity
setSalt(hex);
}
- public String getUserType()
- {
- return userType;
- }
-
- public void setUserType(String userType)
- {
- this.userType = userType;
- }
-
public int getStatus()
{
return status;
@@ -194,16 +190,6 @@ public class User extends BaseEntity
this.status = status;
}
- public String getRefuseDes()
- {
- return refuseDes;
- }
-
- public void setRefuseDes(String refuseDes)
- {
- this.refuseDes = refuseDes;
- }
-
public String getLoginIp()
{
return loginIp;
@@ -259,8 +245,8 @@ public class User extends BaseEntity
{
return "User [userId=" + userId + ", deptId=" + deptId + ", parentId=" + parentId + ", loginName=" + loginName
+ ", userName=" + userName + ", email=" + email + ", phonenumber=" + phonenumber + ", sex=" + sex
- + ", avatar=" + avatar + ", password=" + password + ", salt=" + salt + ", userType=" + userType
- + ", status=" + status + ", refuseDes=" + refuseDes + ", dept=" + dept + ", roleIds="
+ + ", avatar=" + avatar + ", password=" + password + ", salt=" + salt + ", status=" + status
+ + ", loginIp=" + loginIp + ", loginDate=" + loginDate + ", dept=" + dept + ", roleIds="
+ Arrays.toString(roleIds) + ", postIds=" + Arrays.toString(postIds) + "]";
}
diff --git a/src/main/java/com/ruoyi/project/system/user/domain/UserStatus.java b/src/main/java/com/ruoyi/project/system/user/domain/UserStatus.java
new file mode 100644
index 000000000..c833632ec
--- /dev/null
+++ b/src/main/java/com/ruoyi/project/system/user/domain/UserStatus.java
@@ -0,0 +1,31 @@
+package com.ruoyi.project.system.user.domain;
+
+/**
+ * 用户状态
+ *
+ * @author ruoyi
+ *
+ */
+public enum UserStatus
+{
+ OK(0, "正常"), DISABLE(1, "禁用"), DELETED(2, "删除");
+
+ private final int code;
+ private final String info;
+
+ UserStatus(int code, String info)
+ {
+ this.code = code;
+ this.info = info;
+ }
+
+ public int getCode()
+ {
+ return code;
+ }
+
+ public String getInfo()
+ {
+ return info;
+ }
+}
diff --git a/src/main/resources/mybatis/system/UserMapper.xml b/src/main/resources/mybatis/system/UserMapper.xml
index b8ae00c1a..865446019 100644
--- a/src/main/resources/mybatis/system/UserMapper.xml
+++ b/src/main/resources/mybatis/system/UserMapper.xml
@@ -15,15 +15,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
-
-
+
@@ -36,19 +35,18 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"