|
|
@ -7,31 +7,24 @@ import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse; |
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
|
|
|
import com.google.gson.Gson; |
|
|
|
import com.google.gson.Gson; |
|
|
|
import com.teaching.backend.exception.Asserts; |
|
|
|
|
|
|
|
import com.teaching.backend.exception.BusinessException; |
|
|
|
import com.teaching.backend.exception.BusinessException; |
|
|
|
import com.teaching.backend.exception.LyException; |
|
|
|
import com.teaching.backend.mapper.umsAdmin.*; |
|
|
|
import com.teaching.backend.mapper.umsAdmin.UmsAdminMapper; |
|
|
|
import com.teaching.backend.model.dto.umsAdmin.UmsUserParam; |
|
|
|
import com.teaching.backend.mapper.umsAdmin.UmsAdminRoleRelationMapper; |
|
|
|
import com.teaching.backend.model.dto.umsAdmin.UpdateUserPasswordParam; |
|
|
|
import com.teaching.backend.mapper.umsAdmin.UmsStudentMapper; |
|
|
|
|
|
|
|
import com.teaching.backend.mapper.umsAdmin.UmsTeacherMapper; |
|
|
|
|
|
|
|
import com.teaching.backend.model.dto.UmsAdminParam; |
|
|
|
|
|
|
|
import com.teaching.backend.model.dto.UpdateAdminPasswordParam; |
|
|
|
|
|
|
|
import com.teaching.backend.model.dto.umsAdmin.UmsStudentAndTeacherDTO; |
|
|
|
import com.teaching.backend.model.dto.umsAdmin.UmsStudentAndTeacherDTO; |
|
|
|
import com.teaching.backend.model.entity.umsAdmin.*; |
|
|
|
import com.teaching.backend.model.entity.umsAdmin.*; |
|
|
|
import com.teaching.backend.model.vo.courses.TeacherInfVO; |
|
|
|
import com.teaching.backend.model.vo.courses.TeacherInfVO; |
|
|
|
import com.teaching.backend.model.vo.umsAdmin.UmsStudentVO; |
|
|
|
import com.teaching.backend.model.vo.umsAdmin.UmsStudentVO; |
|
|
|
import com.teaching.backend.model.vo.umsAdmin.UmsTeacherVO; |
|
|
|
import com.teaching.backend.model.vo.umsAdmin.UmsTeacherVO; |
|
|
|
import com.teaching.backend.service.umsAdmin.UmsAdminService; |
|
|
|
import com.teaching.backend.service.umsAdmin.UmsUserService; |
|
|
|
import com.teaching.backend.utils.JwtTokenUtil; |
|
|
|
import com.teaching.backend.utils.JwtTokenUtil; |
|
|
|
import com.teaching.backend.utils.RegexUtils; |
|
|
|
import com.teaching.backend.utils.RegexUtils; |
|
|
|
import lombok.extern.slf4j.Slf4j; |
|
|
|
import lombok.extern.slf4j.Slf4j; |
|
|
|
import org.apache.commons.lang3.RandomStringUtils; |
|
|
|
import org.apache.commons.lang3.RandomStringUtils; |
|
|
|
import org.slf4j.Logger; |
|
|
|
import org.slf4j.Logger; |
|
|
|
import org.slf4j.LoggerFactory; |
|
|
|
import org.slf4j.LoggerFactory; |
|
|
|
import org.springframework.amqp.core.AmqpTemplate; |
|
|
|
|
|
|
|
import org.springframework.beans.BeanUtils; |
|
|
|
import org.springframework.beans.BeanUtils; |
|
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
|
import org.springframework.data.redis.core.StringRedisTemplate; |
|
|
|
|
|
|
|
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; |
|
|
|
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; |
|
|
|
import org.springframework.security.core.AuthenticationException; |
|
|
|
import org.springframework.security.core.AuthenticationException; |
|
|
|
import org.springframework.security.core.context.SecurityContextHolder; |
|
|
|
import org.springframework.security.core.context.SecurityContextHolder; |
|
|
@ -51,9 +44,9 @@ import java.util.UUID; |
|
|
|
|
|
|
|
|
|
|
|
@Service |
|
|
|
@Service |
|
|
|
@Slf4j |
|
|
|
@Slf4j |
|
|
|
public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> implements UmsAdminService { |
|
|
|
public class UmsUserServiceImpl extends ServiceImpl<UmsUserMapper, UmsUser> implements UmsUserService { |
|
|
|
|
|
|
|
|
|
|
|
private static final Logger LOGGER = LoggerFactory.getLogger(UmsAdminServiceImpl.class); |
|
|
|
private static final Logger LOGGER = LoggerFactory.getLogger(UmsUserServiceImpl.class); |
|
|
|
@Autowired |
|
|
|
@Autowired |
|
|
|
private JwtTokenUtil jwtTokenUtil; |
|
|
|
private JwtTokenUtil jwtTokenUtil; |
|
|
|
@Autowired |
|
|
|
@Autowired |
|
|
@ -65,37 +58,40 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
@Autowired |
|
|
|
@Autowired |
|
|
|
UmsTeacherMapper umsTeacherMapper; |
|
|
|
UmsTeacherMapper umsTeacherMapper; |
|
|
|
@Autowired |
|
|
|
@Autowired |
|
|
|
UmsAdminMapper umsAdminMapper; |
|
|
|
UmsUserMapper umsUserMapper; |
|
|
|
|
|
|
|
@Autowired |
|
|
|
|
|
|
|
UmsRoleMapper umsRoleMapper; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public UmsAdmin register(UmsAdminParam umsAdminParam) { |
|
|
|
public UmsUser register(UmsUserParam umsAdminParam) { |
|
|
|
UmsAdmin umsAdmin = new UmsAdmin(); |
|
|
|
UmsUser umsUser = new UmsUser(); |
|
|
|
BeanUtils.copyProperties(umsAdminParam, umsAdmin); |
|
|
|
BeanUtils.copyProperties(umsAdminParam, umsUser); |
|
|
|
umsAdmin.setCreateTime(LocalDateTime.now()); |
|
|
|
umsUser.setCreateTime(LocalDateTime.now()); |
|
|
|
umsAdmin.setStatus(1); |
|
|
|
umsUser.setStatus(1); |
|
|
|
//查询是否有相同用户名的用户
|
|
|
|
//查询是否有相同用户名的用户
|
|
|
|
List<UmsAdmin> umsAdminList = lambdaQuery() |
|
|
|
List<UmsUser> umsAdminList = lambdaQuery() |
|
|
|
.eq(UmsAdmin::getUsername, umsAdmin.getUsername()) |
|
|
|
.eq(UmsUser::getUsername, umsUser.getUsername()) |
|
|
|
.list(); |
|
|
|
.list(); |
|
|
|
if (umsAdminList.size() > 0) { |
|
|
|
if (umsAdminList.size() > 0) { |
|
|
|
throw new BusinessException(500,"用户已存在"); |
|
|
|
throw new BusinessException(500,"用户已存在"); |
|
|
|
} |
|
|
|
} |
|
|
|
//将密码进行加密操作
|
|
|
|
//将密码进行加密操作
|
|
|
|
String encodePassword = passwordEncoder.encode(umsAdmin.getPassword()); |
|
|
|
String encodePassword = passwordEncoder.encode(umsUser.getPassword()); |
|
|
|
umsAdmin.setPassword(encodePassword); |
|
|
|
umsUser.setPassword(encodePassword); |
|
|
|
save(umsAdmin); |
|
|
|
|
|
|
|
|
|
|
|
//分配角色(学生)
|
|
|
|
|
|
|
|
umsUser.setRoleId("2"); |
|
|
|
|
|
|
|
save(umsUser); |
|
|
|
|
|
|
|
|
|
|
|
//创建学生信息(默认是学生)
|
|
|
|
//创建学生信息(默认是学生)
|
|
|
|
UmsAdmin byUsername = lambdaQuery().eq(UmsAdmin::getUsername, umsAdmin.getUsername()) |
|
|
|
UmsUser byUsername = lambdaQuery().eq(UmsUser::getUsername, umsUser.getUsername()) |
|
|
|
.one(); |
|
|
|
.one(); |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
umsStudent.setUserId(Math.toIntExact(byUsername.getId())); |
|
|
|
umsStudent.setUserId(Math.toIntExact(byUsername.getId())); |
|
|
|
umsStudentMapper.insert(umsStudent); |
|
|
|
umsStudentMapper.insert(umsStudent); |
|
|
|
|
|
|
|
|
|
|
|
//分配角色(学生)
|
|
|
|
return umsUser; |
|
|
|
adminRoleRelation.insert(byUsername.getId(), 2L); |
|
|
|
|
|
|
|
return umsAdmin; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
@ -127,7 +123,7 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
String token = null; |
|
|
|
String token = null; |
|
|
|
//密码需要客户端加密后传递
|
|
|
|
//密码需要客户端加密后传递
|
|
|
|
try { |
|
|
|
try { |
|
|
|
UmsAdmin phoneAdmin = lambdaQuery().eq(UmsAdmin::getPhone, phone) |
|
|
|
UmsUser phoneAdmin = lambdaQuery().eq(UmsUser::getPhone, phone) |
|
|
|
.one(); |
|
|
|
.one(); |
|
|
|
if (phoneAdmin == null){ |
|
|
|
if (phoneAdmin == null){ |
|
|
|
throw new BusinessException(400,"手机号未注册"); |
|
|
|
throw new BusinessException(400,"手机号未注册"); |
|
|
@ -148,24 +144,39 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public Object getByIdPersonalInfo(String id) { |
|
|
|
public Object getByIdPersonalInfo(String id) { |
|
|
|
UmsRole umsRole = umsAdminMapper.getByIdRoleInfo(id); |
|
|
|
UmsUser umsUser = lambdaQuery().eq(UmsUser::getId, id).one(); |
|
|
|
if (umsRole == null){ |
|
|
|
if (umsUser.getRoleId() == null){ |
|
|
|
throw new BusinessException(500,"用户未分配角色"); |
|
|
|
throw new BusinessException(500,"用户未分配角色"); |
|
|
|
} |
|
|
|
} |
|
|
|
if(umsRole.getStatus()==0){ |
|
|
|
String[] roles = umsUser.getRoleId().split(","); |
|
|
|
|
|
|
|
List<String> roleList = new ArrayList<>(); |
|
|
|
|
|
|
|
for (String role : roles) { |
|
|
|
|
|
|
|
UmsRole umsRole = umsRoleMapper.selectById(role); |
|
|
|
|
|
|
|
if(umsRole.getStatus() == 1){ |
|
|
|
|
|
|
|
roleList.add(role); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (roleList == null){ |
|
|
|
throw new BusinessException(500,"角色被禁用"); |
|
|
|
throw new BusinessException(500,"角色被禁用"); |
|
|
|
} |
|
|
|
} |
|
|
|
if (umsRole.getId() == 1){ |
|
|
|
|
|
|
|
UmsTeacher teacher = umsAdminMapper.getByIdTeacher(id); |
|
|
|
//查询个人信息
|
|
|
|
UmsTeacherVO umsTeacherVO = new UmsTeacherVO(); |
|
|
|
UmsTeacher teacher = umsUserMapper.getByIdTeacher(id); |
|
|
|
|
|
|
|
UmsTeacherVO umsTeacherVO = new UmsTeacherVO(); |
|
|
|
|
|
|
|
if (teacher != null){ |
|
|
|
BeanUtils.copyProperties(teacher,umsTeacherVO); |
|
|
|
BeanUtils.copyProperties(teacher,umsTeacherVO); |
|
|
|
umsTeacherVO.setRoleId(Math.toIntExact(umsRole.getId())); |
|
|
|
} |
|
|
|
|
|
|
|
umsTeacherVO.setRoleId(roleList); |
|
|
|
|
|
|
|
if (teacher != null){ |
|
|
|
return umsTeacherVO; |
|
|
|
return umsTeacherVO; |
|
|
|
}else if (umsRole.getId() == 2){ |
|
|
|
} |
|
|
|
UmsStudentVO student = umsAdminMapper.getByIdStudent(id); |
|
|
|
UmsStudentVO student = umsUserMapper.getByIdStudent(id); |
|
|
|
UmsStudentVO umsStudentVO = new UmsStudentVO(); |
|
|
|
UmsStudentVO umsStudentVO = new UmsStudentVO(); |
|
|
|
|
|
|
|
if (student != null){ |
|
|
|
BeanUtils.copyProperties(student,umsStudentVO); |
|
|
|
BeanUtils.copyProperties(student,umsStudentVO); |
|
|
|
umsStudentVO.setRoleId(Math.toIntExact(umsRole.getId())); |
|
|
|
} |
|
|
|
|
|
|
|
umsStudentVO.setRoleId(roleList); |
|
|
|
|
|
|
|
if (student != null){ |
|
|
|
return umsStudentVO; |
|
|
|
return umsStudentVO; |
|
|
|
} |
|
|
|
} |
|
|
|
return null; |
|
|
|
return null; |
|
|
@ -174,54 +185,59 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public boolean updatePersonalInfo(UmsStudentAndTeacherDTO umsStudentAndTeacherDTO) { |
|
|
|
public boolean updatePersonalInfo(UmsStudentAndTeacherDTO umsStudentAndTeacherDTO) { |
|
|
|
|
|
|
|
|
|
|
|
if (umsStudentAndTeacherDTO.getRoleId() == 1){ |
|
|
|
UmsTeacher umsTeacher = new UmsTeacher(); |
|
|
|
UmsTeacher umsTeacher = new UmsTeacher(); |
|
|
|
BeanUtils.copyProperties(umsStudentAndTeacherDTO,umsTeacher); |
|
|
|
BeanUtils.copyProperties(umsStudentAndTeacherDTO,umsTeacher); |
|
|
|
UmsTeacher teacher = umsTeacherMapper.selectByUserId(umsTeacher.getUserId()); |
|
|
|
System.out.println(umsTeacher); |
|
|
|
|
|
|
|
|
|
|
|
if (teacher != null){ |
|
|
|
return umsTeacherMapper.updateTeacherInfo(umsTeacher); |
|
|
|
return umsTeacherMapper.updateTeacherInfo(umsTeacher); |
|
|
|
} else if (umsStudentAndTeacherDTO.getRoleId() == 2) { |
|
|
|
} |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
|
|
|
|
BeanUtils.copyProperties(umsStudentAndTeacherDTO,umsStudent); |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
|
|
|
|
BeanUtils.copyProperties(umsStudentAndTeacherDTO,umsStudent); |
|
|
|
|
|
|
|
UmsStudent student = umsStudentMapper.selectByUserId(umsStudent.getUserId()); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (student != null){ |
|
|
|
return umsStudentMapper.updateStudentInfo(umsStudent); |
|
|
|
return umsStudentMapper.updateStudentInfo(umsStudent); |
|
|
|
} |
|
|
|
} |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public boolean updateUms(UmsAdmin umsadmin) { |
|
|
|
public boolean updateUms(UmsUser umsUser) { |
|
|
|
List<UmsAdmin> adminList = lambdaQuery().eq(UmsAdmin::getUsername, umsadmin.getUsername()) |
|
|
|
List<UmsUser> adminList = lambdaQuery().eq(UmsUser::getUsername, umsUser.getUsername()) |
|
|
|
.list(); |
|
|
|
.list(); |
|
|
|
if (adminList.size() > 0){ |
|
|
|
if (adminList.size() > 0){ |
|
|
|
throw new BusinessException(400,"用户名已存在"); |
|
|
|
throw new BusinessException(400,"用户名已存在"); |
|
|
|
} |
|
|
|
} |
|
|
|
if (!StrUtil.isEmpty(umsadmin.getPassword())){ |
|
|
|
if (!StrUtil.isEmpty(umsUser.getPassword())){ |
|
|
|
throw new BusinessException(400,"修改操作错误1"); |
|
|
|
throw new BusinessException(400,"修改操作错误1"); |
|
|
|
} |
|
|
|
} |
|
|
|
if (umsadmin.getCreateTime() != null){ |
|
|
|
if (umsUser.getCreateTime() != null){ |
|
|
|
throw new BusinessException(400,"修改操作错误2"); |
|
|
|
throw new BusinessException(400,"修改操作错误2"); |
|
|
|
} |
|
|
|
} |
|
|
|
return umsAdminMapper.updateUserInformation(umsadmin); |
|
|
|
return umsUserMapper.updateUserInformation(umsUser); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public int updatePassword(UpdateAdminPasswordParam param) { |
|
|
|
public int updatePassword(UpdateUserPasswordParam param) { |
|
|
|
if(StrUtil.isEmpty(param.getUsername()) |
|
|
|
if(StrUtil.isEmpty(param.getUsername()) |
|
|
|
||StrUtil.isEmpty(param.getOldPassword()) |
|
|
|
||StrUtil.isEmpty(param.getOldPassword()) |
|
|
|
||StrUtil.isEmpty(param.getNewPassword())){ |
|
|
|
||StrUtil.isEmpty(param.getNewPassword())){ |
|
|
|
throw new BusinessException(400,"修改密码操作错误"); |
|
|
|
throw new BusinessException(400,"修改密码操作错误"); |
|
|
|
} |
|
|
|
} |
|
|
|
List<UmsAdmin> adminList = lambdaQuery() |
|
|
|
List<UmsUser> userList = lambdaQuery() |
|
|
|
.eq(UmsAdmin::getUsername, param.getUsername()) |
|
|
|
.eq(UmsUser::getUsername, param.getUsername()) |
|
|
|
.list(); |
|
|
|
.list(); |
|
|
|
if(CollUtil.isEmpty(adminList)){ |
|
|
|
if(CollUtil.isEmpty(userList)){ |
|
|
|
throw new BusinessException(400,"用户名不存在"); |
|
|
|
throw new BusinessException(400,"用户名不存在"); |
|
|
|
} |
|
|
|
} |
|
|
|
UmsAdmin umsAdmin = adminList.get(0); |
|
|
|
UmsUser umsUser = userList.get(0); |
|
|
|
if(!passwordEncoder.matches(param.getOldPassword(),umsAdmin.getPassword())){ |
|
|
|
if(!passwordEncoder.matches(param.getOldPassword(),umsUser.getPassword())){ |
|
|
|
throw new BusinessException(400,"密码重复"); |
|
|
|
throw new BusinessException(400,"密码重复"); |
|
|
|
} |
|
|
|
} |
|
|
|
umsAdmin.setPassword(passwordEncoder.encode(param.getNewPassword())); |
|
|
|
umsUser.setPassword(passwordEncoder.encode(param.getNewPassword())); |
|
|
|
updateById(umsAdmin); |
|
|
|
updateById(umsUser); |
|
|
|
return 1; |
|
|
|
return 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -231,14 +247,6 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
throw new BusinessException(400, "手机号格式错误"); |
|
|
|
throw new BusinessException(400, "手机号格式错误"); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// UmsAdmin admin = lambdaQuery()
|
|
|
|
|
|
|
|
// .eq(UmsAdmin::getPhone, phone)
|
|
|
|
|
|
|
|
// .one();
|
|
|
|
|
|
|
|
// if (admin != null){
|
|
|
|
|
|
|
|
//// throw new ;
|
|
|
|
|
|
|
|
// return null;
|
|
|
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
String code = RandomStringUtils.randomNumeric(5); |
|
|
|
String code = RandomStringUtils.randomNumeric(5); |
|
|
|
|
|
|
|
|
|
|
|
String ALIBABA_CLOUD_ACCESS_KEY_ID = "LTAI5tF7fcDC5VTj1cVWKDU6"; |
|
|
|
String ALIBABA_CLOUD_ACCESS_KEY_ID = "LTAI5tF7fcDC5VTj1cVWKDU6"; |
|
|
@ -267,34 +275,34 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public UmsAdmin phoneRegister(UmsAdminParam umsAdminParam) { |
|
|
|
public UmsUser phoneRegister(UmsUserParam umsUserParam) { |
|
|
|
UmsAdmin umsAdmin = new UmsAdmin(); |
|
|
|
UmsUser umsUser = new UmsUser(); |
|
|
|
BeanUtils.copyProperties(umsAdminParam, umsAdmin); |
|
|
|
BeanUtils.copyProperties(umsUserParam, umsUser); |
|
|
|
umsAdmin.setCreateTime(LocalDateTime.now()); |
|
|
|
umsUser.setCreateTime(LocalDateTime.now()); |
|
|
|
umsAdmin.setStatus(1); |
|
|
|
umsUser.setStatus(1); |
|
|
|
//查询是否有相同手机号的用户
|
|
|
|
//查询是否有相同手机号的用户
|
|
|
|
List<UmsAdmin> umsAdminList = lambdaQuery() |
|
|
|
List<UmsUser> umsUserList = lambdaQuery() |
|
|
|
.eq(UmsAdmin::getPhone,umsAdminParam.getPhone()) |
|
|
|
.eq(UmsUser::getPhone,umsUserParam.getPhone()) |
|
|
|
.list(); |
|
|
|
.list(); |
|
|
|
if (umsAdminList.size() > 0 ) { |
|
|
|
if (umsUserList.size() > 0 ) { |
|
|
|
throw new BusinessException(400,"手机号已存在"); |
|
|
|
throw new BusinessException(400,"手机号已存在"); |
|
|
|
} |
|
|
|
} |
|
|
|
//将密码进行加密操作
|
|
|
|
//将密码进行加密操作
|
|
|
|
String encodePassword = passwordEncoder.encode(umsAdmin.getPassword()); |
|
|
|
String encodePassword = passwordEncoder.encode(umsUser.getPassword()); |
|
|
|
umsAdmin.setUsername(randomUsername()); |
|
|
|
umsUser.setUsername(randomUsername()); |
|
|
|
umsAdmin.setPassword(encodePassword); |
|
|
|
umsUser.setPassword(encodePassword); |
|
|
|
save(umsAdmin); |
|
|
|
//分配角色(学生)
|
|
|
|
|
|
|
|
umsUser.setRoleId("2"); |
|
|
|
|
|
|
|
save(umsUser); |
|
|
|
|
|
|
|
|
|
|
|
//创建学生信息(默认是学生)
|
|
|
|
//创建学生信息(默认是学生)
|
|
|
|
UmsAdmin byUsername = lambdaQuery().eq(UmsAdmin::getPhone, umsAdmin.getPhone()) |
|
|
|
UmsUser byUsername = lambdaQuery().eq(UmsUser::getPhone, umsUser.getPhone()) |
|
|
|
.one(); |
|
|
|
.one(); |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
UmsStudent umsStudent = new UmsStudent(); |
|
|
|
umsStudent.setUserId(Math.toIntExact(byUsername.getId())); |
|
|
|
umsStudent.setUserId(Math.toIntExact(byUsername.getId())); |
|
|
|
umsStudentMapper.insert(umsStudent); |
|
|
|
umsStudentMapper.insert(umsStudent); |
|
|
|
|
|
|
|
|
|
|
|
//分配角色(学生)
|
|
|
|
return umsUser; |
|
|
|
adminRoleRelation.insert(byUsername.getId(), 2L); |
|
|
|
|
|
|
|
return umsAdmin; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* |
|
|
|
/* |
|
|
@ -302,12 +310,12 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
private String randomUsername(){ |
|
|
|
private String randomUsername(){ |
|
|
|
String username; |
|
|
|
String username; |
|
|
|
UmsAdmin newUsername = new UmsAdmin(); |
|
|
|
UmsUser newUsername = new UmsUser(); |
|
|
|
do { |
|
|
|
do { |
|
|
|
UUID uuid = UUID.randomUUID(); |
|
|
|
UUID uuid = UUID.randomUUID(); |
|
|
|
// 这里只是简单地截取UUID的一部分作为用户名,但你可以根据需要进行更复杂的处理
|
|
|
|
// 这里只是简单地截取UUID的一部分作为用户名,但你可以根据需要进行更复杂的处理
|
|
|
|
username = uuid.toString().substring(0, 10); // 截取前10个字符作
|
|
|
|
username = uuid.toString().substring(0, 10); // 截取前10个字符作
|
|
|
|
newUsername = lambdaQuery().eq(UmsAdmin::getUsername, username) |
|
|
|
newUsername = lambdaQuery().eq(UmsUser::getUsername, username) |
|
|
|
.one(); |
|
|
|
.one(); |
|
|
|
} while ( newUsername != null); // 如果用户名已存在,则重新生成
|
|
|
|
} while ( newUsername != null); // 如果用户名已存在,则重新生成
|
|
|
|
return username; |
|
|
|
return username; |
|
|
@ -324,30 +332,38 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public UmsAdmin getAdminByUsername(String username) { |
|
|
|
public UmsUser getUserByUsername(String username) { |
|
|
|
//从数据库中获取
|
|
|
|
//从数据库中获取
|
|
|
|
UmsAdmin admin = lambdaQuery().eq(UmsAdmin::getUsername, username) |
|
|
|
UmsUser user = lambdaQuery().eq(UmsUser::getUsername, username) |
|
|
|
.one(); |
|
|
|
.one(); |
|
|
|
if (admin != null) { |
|
|
|
if (user != null) { |
|
|
|
return admin; |
|
|
|
return user; |
|
|
|
} |
|
|
|
} |
|
|
|
return null; |
|
|
|
return null; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public List<UmsResource> getResourceList(Long adminId) { |
|
|
|
public List<UmsResource> getResourceList(Long userId) { |
|
|
|
//从数据库中获取
|
|
|
|
//从数据库中获取
|
|
|
|
List<UmsResource> resourceList = adminRoleRelation.getResourceList(adminId); |
|
|
|
List<UmsResource> resourceList = new ArrayList<>(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
UmsUser umsUser = lambdaQuery().eq(UmsUser::getId, userId).one(); |
|
|
|
|
|
|
|
String[] roles = umsUser.getRoleId().split(","); |
|
|
|
|
|
|
|
List<String> roleList = new ArrayList<>(); |
|
|
|
|
|
|
|
for (String role : roles) { |
|
|
|
|
|
|
|
UmsRole umsRole = umsRoleMapper.selectById(role); |
|
|
|
|
|
|
|
resourceList = adminRoleRelation.getResourceList(umsRole.getId()); |
|
|
|
|
|
|
|
} |
|
|
|
return resourceList; |
|
|
|
return resourceList; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public UserDetails loadUserByUsername(String username){ |
|
|
|
public UserDetails loadUserByUsername(String username){ |
|
|
|
//获取用户信息
|
|
|
|
//获取用户信息
|
|
|
|
UmsAdmin admin = getAdminByUsername(username); |
|
|
|
UmsUser user = getUserByUsername(username); |
|
|
|
if (admin != null) { |
|
|
|
if (user != null) { |
|
|
|
List<UmsResource> resourceList = getResourceList(admin.getId()); |
|
|
|
List<UmsResource> resourceList = getResourceList(user.getId()); |
|
|
|
return new AdminUserDetails(admin,resourceList); |
|
|
|
return new AdminUserDetails(user,resourceList); |
|
|
|
} |
|
|
|
} |
|
|
|
throw new UsernameNotFoundException("用户名或密码错误"); |
|
|
|
throw new UsernameNotFoundException("用户名或密码错误"); |
|
|
|
} |
|
|
|
} |
|
|
@ -359,8 +375,8 @@ public class UmsAdminServiceImpl extends ServiceImpl<UmsAdminMapper, UmsAdmin> i |
|
|
|
List<TeacherInfVO> teacherInfList = new ArrayList<>();; |
|
|
|
List<TeacherInfVO> teacherInfList = new ArrayList<>();; |
|
|
|
for (UmsTeacher umsTeacher : umsTeachers) { |
|
|
|
for (UmsTeacher umsTeacher : umsTeachers) { |
|
|
|
teacherInfVO = new TeacherInfVO(); |
|
|
|
teacherInfVO = new TeacherInfVO(); |
|
|
|
UmsAdmin umsAdmin = umsAdminMapper.selectOne(new LambdaQueryWrapper<UmsAdmin>() |
|
|
|
UmsUser umsAdmin = umsUserMapper.selectOne(new LambdaQueryWrapper<UmsUser>() |
|
|
|
.eq(UmsAdmin::getId, umsTeacher.getUserId())); |
|
|
|
.eq(UmsUser::getId, umsTeacher.getUserId())); |
|
|
|
teacherInfVO.setName(umsTeacher.getName()); |
|
|
|
teacherInfVO.setName(umsTeacher.getName()); |
|
|
|
teacherInfVO.setUsername(umsAdmin.getUsername()); |
|
|
|
teacherInfVO.setUsername(umsAdmin.getUsername()); |
|
|
|
teacherInfList.add(teacherInfVO); |
|
|
|
teacherInfList.add(teacherInfVO); |