package com.moral.api.service.impl; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.moral.api.entity.ManageAccount; import com.moral.api.entity.ManageMenu; import com.moral.api.entity.ManageRole; import com.moral.api.mapper.ManageAccountMapper; import com.moral.api.mapper.ManageMenuMapper; import com.moral.api.mapper.ManageRoleMapper; import com.moral.api.pojo.dto.AccountInfoDTO; import com.moral.api.pojo.dto.LoginDTO; import com.moral.api.service.ManageAccountService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.moral.util.AESUtils; import com.moral.util.MD5Utils; import com.moral.util.TokenUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; import javax.annotation.Resource; import java.util.*; /** *

* 后台账户表 服务实现类 *

* * @author moral * @since 2021-03-09 */ @Service public class ManageAccountServiceImpl extends ServiceImpl implements ManageAccountService { @Value("${AES.KEY}") private String AESKey; @Resource ManageAccountMapper accountMapper; @Resource ManageRoleMapper roleMapper; @Resource ManageMenuMapper manageMenuMapper; /** * @Description: 登陆 * @Param: [parameters] * @return: java.util.Map * @Author: 陈凯裕 * @Date: 2021/3/11 */ @Override public LoginDTO login(String AESAccount,String AESPassword) { LoginDTO loginDTO = new LoginDTO(); //解密 String account = AESUtils.decrypt(AESAccount, AESKey); String password = AESUtils.decrypt(AESPassword, AESKey); //查询是否存在 QueryWrapper wrapper = new QueryWrapper<>(); wrapper.eq("account", account); ManageAccount manageAccount = accountMapper.selectOne(wrapper); if (ObjectUtils.isEmpty(manageAccount)) { loginDTO.setCode(LoginDTO.NOT_EXIST); return loginDTO; } //查询是否逻辑删除 if (manageAccount.getIsDelete().equals("1")) { loginDTO.setCode(LoginDTO.IS_DELETE); return loginDTO; } //校验密码 if (!MD5Utils.saltMD5Verify(password, manageAccount.getPassword())) { loginDTO.setCode(LoginDTO.PASSWORD_ERROR); return loginDTO; } //查询角色 List roles = roleMapper.getManageRoleByAccountId(manageAccount.getId()); if (ObjectUtils.isEmpty(roles)) {//判断账号是否存在角色 loginDTO.setCode(LoginDTO.ROLE_EMPTY); return loginDTO; } //查询菜单 List menus = manageMenuMapper.getParentChildrenMenusByRoles(roles); if (ObjectUtils.isEmpty(menus)) {//判断账号是否存在菜单 loginDTO.setCode(LoginDTO.MENU_EMPTY); return loginDTO; } //封装用户信息 AccountInfoDTO accountInfoDTO = new AccountInfoDTO(); /*获取角色名称集合*/ ArrayList roleNames = new ArrayList<>(); roles.forEach(role->roleNames.add(role.getName())); /*过滤menu无用属性*/ for (ManageMenu menu : menus) { menu.setCreateTime(null); menu.setIsDelete(null); menu.setUpdateTime(null); menu.setParentId(null); List children = menu.getChildren(); for (ManageMenu child : children) { child.setCreateTime(null); child.setIsDelete(null); child.setUpdateTime(null); child.setParentId(null); } } accountInfoDTO.setAccountId(String.valueOf(manageAccount.getId())); accountInfoDTO.setAccountName(manageAccount.getUserName()); accountInfoDTO.setMenus(menus); accountInfoDTO.setRoles(roleNames); //获取token 并且存入缓存 String token = TokenUtils.getToken(String.valueOf(manageAccount.getId()), accountInfoDTO); //封装返回结果 loginDTO.setCode(LoginDTO.SUCCESS); loginDTO.setAccountInfo(accountInfoDTO); loginDTO.setToken(token); return loginDTO; } /** * @Description: 注销 * @Param: [parameters] * @return: java.util.Map * @Author: 陈凯裕 * @Date: 2021/3/11 */ @Override public boolean logout(String accountId,String token) { TokenUtils.destoryToken(accountId,token); return true; } }