用户管理更新
This commit is contained in:
@@ -92,6 +92,9 @@ public class AuthorizationController {
|
|||||||
throw new BadRequestException("账号或密码错误");
|
throw new BadRequestException("账号或密码错误");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 判断是否被锁
|
||||||
|
if (!userDto.getEnabled()) throw new BadRequestException("账号未激活");
|
||||||
|
|
||||||
// 获取权限列表 - 登录查找权限
|
// 获取权限列表 - 登录查找权限
|
||||||
List<String> permissionList = roleService.getPermissionList(userDto);
|
List<String> permissionList = roleService.getPermissionList(userDto);
|
||||||
|
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ import cn.dev33.satoken.annotation.SaCheckPermission;
|
|||||||
import cn.dev33.satoken.secure.SaSecureUtil;
|
import cn.dev33.satoken.secure.SaSecureUtil;
|
||||||
import cn.dev33.satoken.stp.StpUtil;
|
import cn.dev33.satoken.stp.StpUtil;
|
||||||
import cn.hutool.core.collection.CollectionUtil;
|
import cn.hutool.core.collection.CollectionUtil;
|
||||||
|
import cn.hutool.core.util.ObjectUtil;
|
||||||
import io.swagger.annotations.Api;
|
import io.swagger.annotations.Api;
|
||||||
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiOperation;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
@@ -109,7 +110,10 @@ public class UserController {
|
|||||||
public ResponseEntity<Object> create(@Validated @RequestBody User resources){
|
public ResponseEntity<Object> create(@Validated @RequestBody User resources){
|
||||||
checkLevel(resources);
|
checkLevel(resources);
|
||||||
// 默认密码 123456
|
// 默认密码 123456
|
||||||
resources.setPassword(SaSecureUtil.md5BySalt("123456", "salt"));
|
if (ObjectUtil.isEmpty(resources.getPassword()))
|
||||||
|
resources.setPassword(SaSecureUtil.md5BySalt("123456", "salt"));
|
||||||
|
else
|
||||||
|
resources.setPassword(SaSecureUtil.md5BySalt(resources.getPassword(), "salt"));
|
||||||
userService.create(resources);
|
userService.create(resources);
|
||||||
return new ResponseEntity<>(HttpStatus.CREATED);
|
return new ResponseEntity<>(HttpStatus.CREATED);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,6 +15,8 @@
|
|||||||
*/
|
*/
|
||||||
package org.nl.modules.system.service.impl;
|
package org.nl.modules.system.service.impl;
|
||||||
|
|
||||||
|
import cn.dev33.satoken.secure.SaSecureUtil;
|
||||||
|
import cn.hutool.core.util.ObjectUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
import cn.hutool.core.util.StrUtil;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.nl.modules.common.config.FileProperties;
|
import org.nl.modules.common.config.FileProperties;
|
||||||
@@ -89,9 +91,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
if (userRepository.findByUsername(resources.getUsername()) != null) {
|
if (userRepository.findByUsername(resources.getUsername()) != null) {
|
||||||
throw new EntityExistException(User.class, "username", resources.getUsername());
|
throw new EntityExistException(User.class, "username", resources.getUsername());
|
||||||
}
|
}
|
||||||
if (userRepository.findByEmail(resources.getEmail()) != null) {
|
|
||||||
throw new EntityExistException(User.class, "email", resources.getEmail());
|
|
||||||
}
|
|
||||||
resources.setCreateBy(SecurityUtils.getCurrentUsername());
|
resources.setCreateBy(SecurityUtils.getCurrentUsername());
|
||||||
userRepository.save(resources);
|
userRepository.save(resources);
|
||||||
}
|
}
|
||||||
@@ -102,45 +101,37 @@ public class UserServiceImpl implements UserService {
|
|||||||
User user = userRepository.findById(resources.getId()).orElseGet(User::new);
|
User user = userRepository.findById(resources.getId()).orElseGet(User::new);
|
||||||
ValidationUtil.isNull(user.getId(), "User", "id", resources.getId());
|
ValidationUtil.isNull(user.getId(), "User", "id", resources.getId());
|
||||||
User user1 = userRepository.findByUsername(resources.getUsername());
|
User user1 = userRepository.findByUsername(resources.getUsername());
|
||||||
User user2 = userRepository.findByEmail(resources.getEmail());
|
|
||||||
|
|
||||||
if (user1 != null && !user.getId().equals(user1.getId())) {
|
if (user1 != null && !user.getId().equals(user1.getId())) {
|
||||||
throw new EntityExistException(User.class, "username", resources.getUsername());
|
throw new EntityExistException(User.class, "username", resources.getUsername());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (user2 != null && !user.getId().equals(user2.getId())) {
|
|
||||||
throw new EntityExistException(User.class, "email", resources.getEmail());
|
|
||||||
}
|
|
||||||
// 如果用户的角色改变
|
// 如果用户的角色改变
|
||||||
if (!resources.getRoles().equals(user.getRoles())) {
|
if (!resources.getRoles().equals(user.getRoles())) {
|
||||||
redisUtils.del(CacheKey.DATA_USER + resources.getId());
|
redisUtils.del(CacheKey.DATA_USER + resources.getId());
|
||||||
redisUtils.del(CacheKey.MENU_USER + resources.getId());
|
redisUtils.del(CacheKey.MENU_USER + resources.getId());
|
||||||
redisUtils.del(CacheKey.ROLE_AUTH + resources.getId());
|
redisUtils.del(CacheKey.ROLE_AUTH + resources.getId());
|
||||||
}
|
}
|
||||||
// 如果用户名称修改
|
// 如果用户名称或者状态修改
|
||||||
if(!resources.getUsername().equals(user.getUsername())){
|
redisUtils.del("user::username:" + user.getUsername());
|
||||||
redisUtils.del("user::username:" + user.getUsername());
|
|
||||||
}
|
|
||||||
// 如果用户被禁用,则清除用户登录信息
|
// 如果用户被禁用,则清除用户登录信息
|
||||||
if(!resources.getEnabled()){
|
if(!resources.getEnabled()){
|
||||||
onlineUserService.kickOutForUsername(resources.getUsername());
|
onlineUserService.kickOutForUsername(resources.getUsername());
|
||||||
}
|
}
|
||||||
User clone = new User(); // jpa 多表问题,需要用新的类来进行修改
|
user.setId(resources.getId());
|
||||||
clone.setId(resources.getId());
|
user.setUsername(resources.getUsername());
|
||||||
clone.setUsername(resources.getUsername());
|
user.setEmail(resources.getEmail());
|
||||||
clone.setEmail(resources.getEmail());
|
user.setEnabled(resources.getEnabled());
|
||||||
clone.setEnabled(resources.getEnabled());
|
user.setRoles(resources.getRoles());
|
||||||
clone.setRoles(resources.getRoles());
|
user.setDept(resources.getDept());
|
||||||
clone.setDept(resources.getDept());
|
user.setPhone(resources.getPhone());
|
||||||
clone.setPhone(resources.getPhone());
|
user.setNickName(resources.getNickName());
|
||||||
clone.setNickName(resources.getNickName());
|
user.setGender(resources.getGender());
|
||||||
clone.setGender(resources.getGender());
|
if (ObjectUtil.isNotEmpty(resources.getPassword()))
|
||||||
|
user.setPassword(SaSecureUtil.md5BySalt(resources.getPassword(), "salt"));
|
||||||
|
|
||||||
userRepository.save(clone);
|
userRepository.save(user);
|
||||||
// 清除缓存
|
// 清除缓存
|
||||||
delCaches(user.getId(), user.getUsername());
|
delCaches(user.getId(), user.getUsername());
|
||||||
// 修改session
|
|
||||||
// flushSession(user);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -153,8 +144,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
userRepository.save(user);
|
userRepository.save(user);
|
||||||
// 清理缓存
|
// 清理缓存
|
||||||
delCaches(user.getId(), user.getUsername());
|
delCaches(user.getId(), user.getUsername());
|
||||||
// 修改session
|
|
||||||
// flushSession(user);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -184,7 +173,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
public void updatePass(String username, String pass) {
|
public void updatePass(String username, String pass) {
|
||||||
userRepository.updatePass(username, pass, new Date());
|
userRepository.updatePass(username, pass, new Date());
|
||||||
redisUtils.del("user::username:" + username);
|
redisUtils.del("user::username:" + username);
|
||||||
// flushSession(userRepository.findByUsername(username));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -200,7 +188,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
FileUtil.del(oldPath);
|
FileUtil.del(oldPath);
|
||||||
}
|
}
|
||||||
@NotBlank String username = user.getUsername();
|
@NotBlank String username = user.getUsername();
|
||||||
// flushSession(user);
|
|
||||||
return new HashMap<String, String>(1) {{
|
return new HashMap<String, String>(1) {{
|
||||||
put("avatar", file.getName());
|
put("avatar", file.getName());
|
||||||
}};
|
}};
|
||||||
@@ -210,7 +197,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
@Transactional(rollbackFor = Exception.class)
|
@Transactional(rollbackFor = Exception.class)
|
||||||
public void updateEmail(String username, String email) {
|
public void updateEmail(String username, String email) {
|
||||||
userRepository.updateEmail(username, email);
|
userRepository.updateEmail(username, email);
|
||||||
// flushSession(userRepository.findByUsername(username));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -239,17 +225,6 @@ public class UserServiceImpl implements UserService {
|
|||||||
*/
|
*/
|
||||||
public void delCaches(Long id, String username) {
|
public void delCaches(Long id, String username) {
|
||||||
redisUtils.del(CacheKey.USER_ID + id);
|
redisUtils.del(CacheKey.USER_ID + id);
|
||||||
// flushCache(username);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 清理 登陆时 用户缓存信息
|
|
||||||
*
|
|
||||||
* @param user /
|
|
||||||
*/
|
|
||||||
// private void flushSession(User user) {
|
|
||||||
// UserDto userDto = this.findByName(user.getUsername());
|
|
||||||
// List<String> permissionList = roleService.getPermissionList(userDto.getId().toString());
|
|
||||||
// flushSessionUtil.flushSessionInfo(userDto, permissionList);
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,7 +80,7 @@
|
|||||||
<el-form-item label="邮箱" prop="email">
|
<el-form-item label="邮箱" prop="email">
|
||||||
<el-input v-model="form.email" style="width: 200px;" />
|
<el-input v-model="form.email" style="width: 200px;" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="部门" prop="dept.id">
|
<el-form-item label="部门" prop="dept.id" :rules="[{ required: true, message: '请选择部门', trigger: 'change' }]">
|
||||||
<treeselect
|
<treeselect
|
||||||
v-model="form.dept.id"
|
v-model="form.dept.id"
|
||||||
:options="depts"
|
:options="depts"
|
||||||
@@ -89,7 +89,10 @@
|
|||||||
placeholder="选择部门"
|
placeholder="选择部门"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<br v-if="!crud.status.add">
|
||||||
|
<el-form-item label="密码" prop="password" v-if="crud.status.add">
|
||||||
|
<el-input v-model="form.password" style="width: 200px;" show-password auto-complete="new-password"/>
|
||||||
|
</el-form-item>
|
||||||
<el-form-item label="性别">
|
<el-form-item label="性别">
|
||||||
<el-radio-group v-model="form.gender" style="width: 178px">
|
<el-radio-group v-model="form.gender" style="width: 178px">
|
||||||
<el-radio label="男">男</el-radio>
|
<el-radio label="男">男</el-radio>
|
||||||
@@ -168,16 +171,26 @@
|
|||||||
<el-table-column
|
<el-table-column
|
||||||
v-permission="['admin','user:edit','user:del']"
|
v-permission="['admin','user:edit','user:del']"
|
||||||
label="操作"
|
label="操作"
|
||||||
width="115"
|
width="200"
|
||||||
align="center"
|
align="center"
|
||||||
fixed="right"
|
fixed="right"
|
||||||
>
|
>
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<udOperation
|
<udOperation
|
||||||
|
style="display: inline"
|
||||||
:data="scope.row"
|
:data="scope.row"
|
||||||
:permission="permission"
|
:permission="permission"
|
||||||
:disabled-dle="scope.row.id === user.id"
|
:disabled-dle="scope.row.id === user.id"
|
||||||
/>
|
/>
|
||||||
|
<el-button
|
||||||
|
v-permission="permission.edit"
|
||||||
|
type="text"
|
||||||
|
slot="left"
|
||||||
|
icon="el-icon-refresh-left"
|
||||||
|
@click="resetPassword(scope.row)"
|
||||||
|
>
|
||||||
|
重置密码
|
||||||
|
</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
@@ -212,7 +225,8 @@ const defaultForm = {
|
|||||||
enabled: 'true',
|
enabled: 'true',
|
||||||
roles: [],
|
roles: [],
|
||||||
dept: { id: null },
|
dept: { id: null },
|
||||||
phone: null
|
phone: null,
|
||||||
|
password: null
|
||||||
}
|
}
|
||||||
export default {
|
export default {
|
||||||
name: 'User',
|
name: 'User',
|
||||||
@@ -256,7 +270,7 @@ export default {
|
|||||||
])
|
])
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.crud.msg.add = '新增成功,默认密码:123456'
|
this.crud.msg.add = '新增成功'
|
||||||
},
|
},
|
||||||
mounted: function() {
|
mounted: function() {
|
||||||
const that = this
|
const that = this
|
||||||
@@ -292,6 +306,7 @@ export default {
|
|||||||
},
|
},
|
||||||
// 新增前将多选的值设置为空
|
// 新增前将多选的值设置为空
|
||||||
[CRUD.HOOK.beforeToAdd]() {
|
[CRUD.HOOK.beforeToAdd]() {
|
||||||
|
this.form.password = '123456'
|
||||||
this.roleDatas = []
|
this.roleDatas = []
|
||||||
},
|
},
|
||||||
// 初始化编辑时候的角色与岗位
|
// 初始化编辑时候的角色与岗位
|
||||||
@@ -435,6 +450,28 @@ export default {
|
|||||||
},
|
},
|
||||||
checkboxT(row, rowIndex) {
|
checkboxT(row, rowIndex) {
|
||||||
return row.id !== this.user.id
|
return row.id !== this.user.id
|
||||||
|
},
|
||||||
|
resetPassword(row) {
|
||||||
|
row.password = null
|
||||||
|
this.$prompt('', '重置密码', {
|
||||||
|
confirmButtonText: '确定',
|
||||||
|
cancelButtonText: '取消',
|
||||||
|
inputPlaceholder: '请输入新的密码',
|
||||||
|
inputPattern: /^[A-Z|a-z|0-9|(._~!@#$^&*)]{6,20}$/,
|
||||||
|
inputErrorMessage: '密码格式不正确,只能是6-20位密码',
|
||||||
|
closeOnClickModal: false
|
||||||
|
}).then(({ value }) => {
|
||||||
|
row.password = value
|
||||||
|
crudUser.edit(row).then(res => {
|
||||||
|
this.crud.toQuery()
|
||||||
|
this.crud.notify('密码重置成功', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||||
|
})
|
||||||
|
}).catch(() => {
|
||||||
|
this.$message({
|
||||||
|
type: 'info',
|
||||||
|
message: '取消输入'
|
||||||
|
})
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user