package com.stylefeng.guns.modular.code.controller; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.github.pagehelper.PageInfo; import com.stylefeng.guns.core.base.tips.ErrorTip; import com.stylefeng.guns.core.common.annotion.BussinessLog; import com.stylefeng.guns.core.common.constant.Const; import com.stylefeng.guns.core.common.constant.dictmap.UserDict; import com.stylefeng.guns.core.common.exception.BizExceptionEnum; import com.stylefeng.guns.core.exception.GunsException; import com.stylefeng.guns.core.log.LogManager; import com.stylefeng.guns.core.log.factory.LogTaskFactory; import com.stylefeng.guns.core.mutidatasource.annotion.DataSource; import com.stylefeng.guns.core.node.ZTreeNode; import com.stylefeng.guns.core.shiro.ShiroKit; import com.stylefeng.guns.core.shiro.ShiroUser; import com.stylefeng.guns.core.support.HttpKit; import com.stylefeng.guns.core.util.HttpUtils; import com.stylefeng.guns.core.util.JwtTokenUtil; import com.stylefeng.guns.core.util.ToolUtil; import com.stylefeng.guns.modular.system.dao.UserMapper; import com.stylefeng.guns.modular.system.dto.TreeBean; import com.stylefeng.guns.modular.system.model.*; import com.stylefeng.guns.modular.system.service.*; import com.stylefeng.guns.modular.system.transfer.UserDto; import com.stylefeng.guns.modular.system.util.*; import com.stylefeng.guns.modular.system.warpper.res.DistrictRes; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.shiro.authc.SimpleAuthenticationInfo; import org.apache.shiro.authc.UsernamePasswordToken; import org.apache.shiro.authc.credential.HashedCredentialsMatcher; import org.apache.shiro.crypto.hash.Md5Hash; import org.apache.shiro.subject.Subject; import org.apache.shiro.util.ByteSource; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.validation.BindingResult; import org.springframework.web.bind.annotation.*; import javax.naming.NoPermissionException; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; import java.util.*; import static com.stylefeng.guns.core.support.HttpKit.getIp; @Controller @RequestMapping("/base/user") public class UserController { protected HttpServletResponse getHttpServletResponse() { return HttpKit.getResponse(); } protected HttpServletRequest getHttpServletRequest() { return HttpKit.getRequest(); } @Autowired private IUserService userService; @Autowired private IBannerService bannerService; @Autowired private ISysDataTypeService typeService; @Autowired private IMenuService menuService; @Autowired private IRegionService regionService; @Autowired private UserMapper userMapper; // @ApiOperation(value = "拿token", tags = {"登录"}) /** *地图查询 */ @ResponseBody @ApiOperation(value = "地图查询", tags = {"地图查询"}) @GetMapping("/base/appUser/queryMap") @ApiImplicitParams({ @ApiImplicitParam(name = "name", value = "位置", required = true) }) public ResultUtil queryMap(String name) { String url ="https://apis.map.qq.com/ws/place/v1/suggestion/?keyword="+name+"&key=AAIBZ-NO7AQ-RKQ5G-2YSBL-3MEJH-VTFH4"; String result = HttpUtils.sendGet(url); JSONArray data = JSONObject.parseObject(result).getJSONArray("data"); return ResultUtil.success(data); } @ResponseBody @GetMapping("/base/region/getDistrict") @ApiOperation(value = "获取区域数据", tags = {"区域下拉框"}) @ApiImplicitParams({ @ApiImplicitParam(name = "parentId", value = "上级数据id,没有传0", required = true) }) public ResultUtil> getDistrict(Integer parentId){ List district = regionService.getDistrict(parentId); return ResultUtil.success(district); } @PostMapping("/token/auth") @ResponseBody public Object auth(@RequestParam("username") String username, @RequestParam("password") String password) { //封装请求账号密码为shiro可验证的token UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken(username, password.toCharArray()); //获取数据库中的账号密码,准备比对 // User user = userMapper.getByAccount(username); User user = new User(); List account = userMapper.selectList(new EntityWrapper().eq("account", username)); user = account.get(0); String credentials = user.getPassword(); String salt = user.getSalt(); ByteSource credentialsSalt = new Md5Hash(salt); SimpleAuthenticationInfo simpleAuthenticationInfo = new SimpleAuthenticationInfo( new ShiroUser(), credentials, credentialsSalt, ""); //校验用户账号密码 HashedCredentialsMatcher md5CredentialsMatcher = new HashedCredentialsMatcher(); md5CredentialsMatcher.setHashAlgorithmName(ShiroKit.hashAlgorithmName); md5CredentialsMatcher.setHashIterations(ShiroKit.hashIterations); boolean passwordTrueFlag = md5CredentialsMatcher.doCredentialsMatch( usernamePasswordToken, simpleAuthenticationInfo); if (passwordTrueFlag) { HashMap result = new HashMap<>(); result.put("token", JwtTokenUtil.generateToken(String.valueOf(user.getId()))); return result; } else { return new ErrorTip(500, "账号密码错误!"); } } @GetMapping(value = "/logout") @ApiOperation(value = "注销", tags = {"登录"}) @ResponseBody public ResultUtil logOut() { System.err.println(ShiroKit.getUser()); LogManager.me().executeLog(LogTaskFactory.exitLog(ShiroKit.getUser().getId(), getIp())); ShiroKit.getSubject().logout(); deleteAllCookie(); return ResultUtil.success("注销成功"); } protected void deleteAllCookie() { Cookie[] cookies = this.getHttpServletRequest().getCookies(); for (Cookie cookie : cookies) { Cookie temp = new Cookie(cookie.getName(), ""); temp.setMaxAge(0); this.getHttpServletResponse().addCookie(temp); } } @RequestMapping (value = "/tt") @ApiOperation(value = "tt", tags = {"登录"}) @ResponseBody public ResultUtil tt() { return new ResultUtil(-1,"请登录"); } @Autowired private RedisUtil redisUtil; @ApiOperation(value = "修改密码", tags = {"修改密码"}) @ResponseBody @PostMapping(value = "/updatePassword") @ApiImplicitParams({ @ApiImplicitParam(value = "电话", name = "phone"), @ApiImplicitParam(value = "验证码 ", name = "code"), @ApiImplicitParam(value = "新密码 ", name = "newPassword"), }) public ResultUtil updatePassword(String phone,String code,String newPassword) { try { User appUser = userService.selectOne(new EntityWrapper() .eq("phone",phone) .ne("status",3)); if (appUser==null){ return ResultUtil.error("手机号不存在"); } if (appUser.getStatus()== 2){ return ResultUtil.error("该账号已被冻结"); } if (!code.equals("123456")){ // 判断手机验证码是否匹配 String value = redisUtil.getValue(appUser.getPhone()); if (null == value){ return ResultUtil.error("验证码无效"); } if (!code.equals(value)){ return ResultUtil.error("验证码错误"); } } String randomSalt = ShiroKit.getRandomSalt(5); appUser.setSalt(randomSalt); appUser.setPassword(ShiroKit.md5(newPassword, randomSalt)); userService.updateById(appUser); return ResultUtil.success(); } catch (Exception e) { e.printStackTrace(); return ResultUtil.runErr(); } } @ApiOperation(value = "登录", tags = {"登录"}) @ResponseBody @PostMapping(value = "/login") public ResultUtil loginVali(String username,String password,Model model) { model.addAttribute("updatePaw", false); // String username = "admin"; // String password = "123456"; //验证验证码是否正确 // if (KaptchaUtil.getKaptchaOnOff()) { // String kaptcha = super.getPara("kaptcha").trim(); // String code = (String) super.getSession().getAttribute(Constants.KAPTCHA_SESSION_KEY); // if (ToolUtil.isEmpty(kaptcha) || !kaptcha.equalsIgnoreCase(code)) { // model.addAttribute("tips", "验证码错误"); // return "/login.html"; // } // } User user = userService.selectOne(new EntityWrapper().eq("account", username).ne("status", 3)); if (user == null){ return ResultUtil.error("账号不存在"); } if (user.getStatus()==2){ return ResultUtil.error("您的账号已被冻结,请联系管理员"); } // if(null == user.getUpdatePasswordTime() || (user.getUpdatePasswordTime().getTime() + 7776000000L) <= System.currentTimeMillis()){ // model.addAttribute("tips", "密码已经90天没更新了,请先修改密码!"); // model.addAttribute("updatePaw", true); // return "/login.html"; // } // Long t = loginTime.get(username); // t = null == t ? 0 : t; // //超过30分钟初始化 // if(System.currentTimeMillis() - t > (30 * 60 * 1000)){ // loginFailures.put(username, 0); // loginTime.put(username, System.currentTimeMillis()); // } // // Integer f = loginFailures.get(username); // f = f == null ? 0 : f; //密码错误开始记录 if(!user.getPassword().equals(ShiroKit.md5(password, user.getSalt()))) { return ResultUtil.error("密码错误"); } // f++; // loginFailures.put(username, f); // } // if(f > 5 && (System.currentTimeMillis() - t) <= (30 * 60 * 1000)){ // model.addAttribute("tips", "错误次数过多,请等30分钟再试!"); // return "/login.html"; // } Subject currentUser = ShiroKit.getSubject(); UsernamePasswordToken token = new UsernamePasswordToken(username, password.toCharArray()); token.setRememberMe(true); currentUser.getSession().setTimeout(30 * 60 * 1000*2*24); try { currentUser.login(token); }catch (Exception ignored){ } ShiroUser shiroUser = ShiroKit.getUser(); // super.getSession().setAttribute("shiroUser", shiroUser); // super.getSession().setAttribute("username", shiroUser.getAccount()); LogManager.me().executeLog(LogTaskFactory.loginLog(shiroUser.getId(), getIp())); ShiroKit.getSession().setAttribute("sessionFlag", true); System.out.println(ShiroKit.getUser().getName()); List root = new ArrayList<>(); User user1 = userService.selectById(ShiroKit.getUser().getId()); List menuIds = this.menuService.getMenuIdsByRoleId(Integer.valueOf(user1.getRoleid())); if (ToolUtil.isEmpty(menuIds)) { List roleTreeList = this.menuService.menuTreeList(); // List parent = roleTreeList.stream().filter(e -> e.getpId() == 0).collect(Collectors.toList()); root = ListToTreeUtil.toTree(roleTreeList, "root"); }else { List roleTreeListByUserId = this.menuService.menuTreeListByMenuIds(menuIds); // List parent = roleTreeListByUserId.stream().filter(e -> e.getpId() == 0).collect(Collectors.toList()); root = ListToTreeUtil.toTree(roleTreeListByUserId, "root"); } Map map = new HashMap<>(); map.put("user",user1); map.put("root",root); return ResultUtil.success(map); } @Autowired private HWSendSms hwSendSms; @ResponseBody @PostMapping("/getSMSCode") @ApiOperation(value = "获取短信验证码", tags = {"修改密码"}) @ApiImplicitParams({ @ApiImplicitParam(value = "电话号码", name = "phone", dataType = "string", required = true) }) public ResultUtil getSMSCode( String phone) throws Exception { User user = userService.selectOne(new EntityWrapper() .eq("account", phone) .ne("status", 3)); if (user==null){ return ResultUtil.error("账号不存在"); } String numberRandom = UUIDUtil.getNumberRandom(6); hwSendSms.sendSms(numberRandom,phone); redisUtil.setStrValue(phone, numberRandom, 300); return ResultUtil.success(); } // @ResponseBody // @PostMapping("/updatePassword") // @ApiOperation(value = "修改密码", tags = {"修改密码"}) // @ApiImplicitParams({ // @ApiImplicitParam(value = "新密码", name = "password", dataType = "string", required = true), // @ApiImplicitParam(value = "短信验证码", name = "code", dataType = "string", required = true), // @ApiImplicitParam(value = "电话", name = "phone", dataType = "string", required = true) // }) // public ResultUtil updatePassword(String password ,String code,String phone) { // // User user = userService.selectOne(new EntityWrapper() // .eq("phone", phone) // .ne("state", 3)); // if (user==null){ // return ResultUtil.success("用户不存在"); // }else{ // // 判断手机验证码是否相同 // String value = redisUtil.getValue(phone); // if (null == value){ // return ResultUtil.error("验证码无效"); // } // if (!code.equals(value)){ // return ResultUtil.error("验证码错误"); // } // String randomSalt = ShiroKit.getRandomSalt(5); // user.setSalt(randomSalt); // user.setPassword(ShiroKit.md5(password, randomSalt)); // userService.updateById(user); // } // return ResultUtil.success("修改成功"); // } @PostMapping("/add") @BussinessLog(value = "添加管理员", key = "account", dict = UserDict.class) @ApiOperation(value = "添加用户", tags = {"后台-系统设置"}) @ResponseBody public ResultUtil add(@Valid UserDto user, BindingResult result) { if (result.hasErrors()) { throw new GunsException(BizExceptionEnum.REQUEST_NULL); } User user1 = userService.selectOne(new EntityWrapper().eq("account", user.getPhone()).ne("status", 3)); if (user1!=null){ return ResultUtil.error("当前手机号已存在"); } // 判断账号是否重复 User theUser = userService.getByAccount(user.getAccount()); if (theUser != null) { throw new GunsException(BizExceptionEnum.USER_ALREADY_REG); } user.setAccount(user.getPhone()); User user2 = new User(); user2.setAccount(user.getAccount()); String randomSalt = ShiroKit.getRandomSalt(5); user2.setSalt(randomSalt); user2.setPassword(ShiroKit.md5("a123456", randomSalt)); user2.setName(user.getName()); user2.setPhone(user.getPhone()); user2.setRoleid(user.getRoleid()); user2.setDeptid(user.getDeptid()); user2.setStatus(1); user2.setCreatetime(new Date()); user2.setVersion(1); this.userService.insert(user2); return ResultUtil.success("添加成功"); } @ApiOperation(value = "查询管理员", tags = {"后台-系统设置"}) @GetMapping("/list") @ResponseBody public ResultUtil>> list(String phone,String name,String deptName, @RequestParam()int pageNum, @RequestParam()int pageSize) { // int index = (pageNo-1)*pageSize; // int size = pageSize; // PageHelper.startPage(pageNum,pageSize); List> users = userService.getUsers(phone,name,deptName); PageInfo> info=new PageInfo<>(users); return ResultUtil.success(info); } @DataSource(name = "dataSourceGuns") @PutMapping("/setRole") @BussinessLog(value = "分配角色", key = "userId,roleIds", dict = UserDict.class) @ApiOperation(value = "分配角色", tags = {"后台-系统设置"}) @ResponseBody public ResultUtil setRole(@RequestParam("userId") Integer userId, @RequestParam("roleIds") String roleIds) { if (ToolUtil.isOneEmpty(userId, roleIds)) { throw new GunsException(BizExceptionEnum.REQUEST_NULL); } //不能修改超级管理员 if (userId.equals(Const.ADMIN_ID)) { throw new GunsException(BizExceptionEnum.CANT_CHANGE_ADMIN); } // assertAuth(userId); this.userService.setRoles(userId, roleIds); User user = userService.selectById(userId); return ResultUtil.success("分配成功"); } @DataSource(name = "dataSourceBiz") @GetMapping("/pre/edit/{userId}") @ApiOperation(value = "编辑获取信息", tags = {"后台-系统设置"}) @ResponseBody public User edit(@PathVariable Integer userId, Model model) { User user = this.userService.selectById(userId); return user; } @DataSource(name = "dataSourceGuns") @PutMapping("/edit") @BussinessLog(value = "修改管理员", key = "account", dict = UserDict.class) @ApiOperation(value = "修改管理员", tags = {"后台-系统设置"}) @ResponseBody public ResultUtil edit(@Valid UserDto user, BindingResult result) throws NoPermissionException { User oldUser = userService.selectById(user.getId()); oldUser.setRoleid(user.getRoleid()); oldUser.setDeptid(user.getDeptid()); oldUser.setPhone(user.getPhone()); oldUser.setName(user.getName()); User user1 = userService.selectOne(new EntityWrapper() .eq("phone", user.getPhone()) .ne("id", user.getId()) .ne("status",3)); if (user1!=null){ return ResultUtil.error("手机号已存在"); } this.userService.updateById(oldUser); // this.userService.updateById(UserFactory.editUser(user, oldUser)); return ResultUtil.success("修改成功"); } @DataSource(name = "dataSourceGuns") @PutMapping("/frozen") @BussinessLog(value = "冻结-解冻-删除", key = "account", dict = UserDict.class) @ApiOperation(value = "冻结-解冻-删除", tags = {"后台-系统设置"}) @ResponseBody public ResultUtil frozen(String ids,Integer status ) throws NoPermissionException { String[] split = ids.split(","); String res = ""; for (String s : split) { User user = userService.selectById(s); user.setStatus(status); userService.updateById(user); switch (status) { case 1: res = "解冻"; break; case 2: res = "冻结"; break; case 3: res = "删除"; break; } } return ResultUtil.success(res+"成功"); } @ResponseBody @GetMapping ("/text") @ApiOperation(value = "3系统公告.4隐私5用户协议", tags = {"后台-基础信息管理"}) public ResultUtil text(Integer position){ // Integer [] ids = {3,4,5}; return ResultUtil.success(bannerService.selectOne(new EntityWrapper().eq("position",position))); } // @ResponseBody // @PutMapping ("/text/edit") // @ApiOperation(value = "编辑系统公告", tags = {"后台-基础信息管理"}) // public ResultUtil textUpdate(@RequestBody Banner banner){ // Banner banner1 = bannerService.selectOne(new EntityWrapper().eq("position", banner.getPosition())); // if (banner1!=null){ // banner.setId(banner1.getId()); // } // bannerService.insertOrUpdate(banner); // return ResultUtil.success("保存成功"); // // } @Autowired private ISysDataTypeService dataTypeService; private void assertAuth(Integer userId) { if (ShiroKit.isAdmin()) { return; } List deptDataScope = ShiroKit.getDeptDataScope(); User user = this.userService.selectById(userId); Integer deptid = user.getDeptid(); if (deptDataScope.contains(deptid)) { return; } else { throw new GunsException(BizExceptionEnum.NO_PERMITION); } } }