UserController.java 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. /**
  2. * Copyright &copy; 2015-2020 <a href="http://www.jeeplus.org/">JeePlus</a> All rights reserved.
  3. */
  4. package com.jeeplus.modules.sys.web;
  5. import java.io.File;
  6. import java.io.IOException;
  7. import java.io.UnsupportedEncodingException;
  8. import java.net.URLDecoder;
  9. import java.util.ArrayList;
  10. import java.util.Arrays;
  11. import java.util.List;
  12. import java.util.Map;
  13. import javax.servlet.http.HttpServletRequest;
  14. import javax.servlet.http.HttpServletResponse;
  15. import javax.validation.ConstraintViolationException;
  16. import com.jeeplus.common.utils.ConfigMapUtil;
  17. import org.apache.shiro.authz.annotation.Logical;
  18. import org.apache.shiro.authz.annotation.RequiresPermissions;
  19. import org.apache.shiro.session.Session;
  20. import org.aspectj.weaver.loadtime.Aj;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.stereotype.Controller;
  23. import org.springframework.ui.Model;
  24. import org.springframework.web.bind.annotation.ModelAttribute;
  25. import org.springframework.web.bind.annotation.RequestMapping;
  26. import org.springframework.web.bind.annotation.RequestMethod;
  27. import org.springframework.web.bind.annotation.RequestParam;
  28. import org.springframework.web.bind.annotation.ResponseBody;
  29. import org.springframework.web.multipart.MultipartFile;
  30. import org.springframework.web.servlet.mvc.support.RedirectAttributes;
  31. import com.google.common.collect.Lists;
  32. import com.google.common.collect.Maps;
  33. import com.jeeplus.common.beanvalidator.BeanValidators;
  34. import com.jeeplus.common.config.Global;
  35. import com.jeeplus.common.json.AjaxJson;
  36. import com.jeeplus.common.utils.DateUtils;
  37. import com.jeeplus.common.utils.FileUtils;
  38. import com.jeeplus.common.utils.StringUtils;
  39. import com.jeeplus.common.utils.excel.ExportExcel;
  40. import com.jeeplus.common.utils.excel.ImportExcel;
  41. import com.jeeplus.core.persistence.Page;
  42. import com.jeeplus.core.web.BaseController;
  43. import com.jeeplus.modules.sys.entity.Office;
  44. import com.jeeplus.modules.sys.entity.Role;
  45. import com.jeeplus.modules.sys.entity.SystemConfig;
  46. import com.jeeplus.modules.sys.entity.User;
  47. import com.jeeplus.modules.sys.mapper.UserMapper;
  48. import com.jeeplus.modules.sys.service.SystemConfigService;
  49. import com.jeeplus.modules.sys.service.SystemService;
  50. import com.jeeplus.modules.sys.utils.UserUtils;
  51. import com.jeeplus.modules.tools.utils.TwoDimensionCode;
  52. /**
  53. * 用户Controller
  54. *
  55. * @author jeeplus
  56. * @version 2016-8-29
  57. */
  58. @Controller
  59. @RequestMapping(value = "${adminPath}/sys/user")
  60. public class UserController extends BaseController {
  61. @Autowired
  62. private SystemConfigService systemConfigService;
  63. @Autowired
  64. private SystemService systemService;
  65. @Autowired
  66. private UserMapper userMapper;
  67. @ModelAttribute
  68. public User get(@RequestParam(required = false) String id) {
  69. if (StringUtils.isNotBlank(id)) {
  70. return systemService.getUser(id);
  71. } else {
  72. return new User();
  73. }
  74. }
  75. @RequiresPermissions("sys:user:index")
  76. @RequestMapping(value = "index")
  77. public String index(User user, Model model) {
  78. return "modules/sys/user/userIndex";
  79. }
  80. @RequiresPermissions("sys:user:index")
  81. @RequestMapping(value = "userSelect")
  82. public String userSelect(Model model, HttpServletRequest request, String roleName) {
  83. try {
  84. roleName = URLDecoder.decode(roleName, "UTF-8");
  85. } catch (UnsupportedEncodingException e) {
  86. e.printStackTrace();
  87. }
  88. model.addAttribute("roleName", roleName);
  89. return "modules/common/userSelect";
  90. }
  91. @RequiresPermissions("sys:user:index")
  92. @ResponseBody
  93. @RequestMapping(value = {"list", ""})
  94. public Map<String, Object> list(User user, HttpServletRequest request, HttpServletResponse response, Model model,String roleName) {
  95. if (roleName != null) {
  96. String[] split = roleName.split(";");
  97. Role role = new Role();
  98. List<Role> roleList = new ArrayList<>();
  99. for (int i = 0; i < split.length; i++) {
  100. role.setName(split[i]);
  101. roleList.add(role);
  102. }
  103. user.setRoleList(roleList);
  104. }
  105. Page<User> page = systemService.findUser(new Page<User>(request, response), user);
  106. return getBootstrapData(page);
  107. }
  108. @RequiresPermissions(value = {"sys:user:view", "sys:user:add", "sys:user:edit"}, logical = Logical.OR)
  109. @RequestMapping(value = "form")
  110. public String form(User user, Model model) {
  111. if (user.getCompany() == null || user.getCompany().getId() == null) {
  112. user.setCompany(UserUtils.getUser().getCompany());
  113. }
  114. if (user.getOffice() == null || user.getOffice().getId() == null) {
  115. user.setOffice(UserUtils.getUser().getOffice());
  116. }
  117. model.addAttribute("user", user);
  118. model.addAttribute("allRoles", systemService.findRole(new Role()));
  119. return "modules/sys/user/userForm";
  120. }
  121. @RequiresPermissions(value = {"sys:user:add", "sys:user:edit"}, logical = Logical.OR)
  122. @ResponseBody
  123. @RequestMapping(value = "save")
  124. public AjaxJson save(User user, HttpServletRequest request, Model model) {
  125. AjaxJson j = new AjaxJson();
  126. if (Global.isDemoMode()) {
  127. j.setSuccess(false);
  128. j.setMsg("演示模式,不允许操作!");
  129. return j;
  130. }
  131. // 修正引用赋值问题,不知道为何,Company和Office引用的一个实例地址,修改了一个,另外一个跟着修改。
  132. user.setCompany(new Office(request.getParameter("company.id")));
  133. user.setOffice(new Office(request.getParameter("office.id")));
  134. // 如果新密码为空,则不更换密码
  135. if (StringUtils.isNotBlank(user.getNewPassword())) {
  136. user.setPassword(SystemService.entryptPassword(user.getNewPassword()));
  137. }
  138. /**
  139. * 后台hibernate-validation插件校验
  140. */
  141. String errMsg = beanValidator(user);
  142. if (StringUtils.isNotBlank(errMsg)) {
  143. j.setSuccess(false);
  144. j.setMsg(errMsg);
  145. return j;
  146. }
  147. if (!"true".equals(checkLoginName(user.getOldLoginName(), user.getLoginName()))) {
  148. j.setSuccess(false);
  149. j.setMsg("保存用户'" + user.getLoginName() + "'失败,登录名已存在!");
  150. return j;
  151. }
  152. // 角色数据有效性验证,过滤不在授权内的角色
  153. List<Role> roleList = Lists.newArrayList();
  154. List<String> roleIdList = user.getRoleIdList();
  155. for (Role r : systemService.findAllRole()) {
  156. if (roleIdList.contains(r.getId())) {
  157. roleList.add(r);
  158. }
  159. }
  160. user.setRoleList(roleList);
  161. //生成用户二维码,使用登录名
  162. String realPath = Global.getAttachmentDir() + "qrcode/";
  163. FileUtils.createDirectory(realPath);
  164. String name = user.getId() + ".png"; //encoderImgId此处二维码的图片名
  165. String filePath = realPath + name; //存放路径
  166. TwoDimensionCode.encoderQRCode(user.getLoginName(), filePath, "png");//执行生成二维码
  167. user.setQrCode(Global.getAttachmentUrl() + "qrcode/" + name);
  168. // 保存用户信息
  169. systemService.saveUser(user);
  170. // 清除当前用户缓存
  171. if (user.getLoginName().equals(UserUtils.getUser().getLoginName())) {
  172. UserUtils.clearCache();
  173. //UserUtils.getCacheMap().clear();
  174. }
  175. j.setSuccess(true);
  176. j.setMsg("保存用户'" + user.getLoginName() + "'成功!");
  177. return j;
  178. }
  179. @ResponseBody
  180. @RequiresPermissions("sys:user:del")
  181. @RequestMapping(value = "delete")
  182. public AjaxJson delete(User user) {
  183. AjaxJson j = new AjaxJson();
  184. if (Global.isDemoMode()) {
  185. j.setSuccess(false);
  186. j.setMsg("演示模式,不允许操作!");
  187. return j;
  188. }
  189. if (UserUtils.getUser().getId().equals(user.getId())) {
  190. j.setSuccess(false);
  191. j.setMsg("删除失败,不允许删除当前用户!");
  192. return j;
  193. } else if (User.isAdmin(user.getId())) {
  194. j.setSuccess(false);
  195. j.setMsg("删除失败,不允许删除超级管理员!");
  196. return j;
  197. } else {
  198. systemService.deleteUser(user);//删除用户成功
  199. j.setSuccess(true);
  200. j.setMsg("删除成功!");
  201. return j;
  202. }
  203. }
  204. /**
  205. * 批量删除用户
  206. */
  207. @ResponseBody
  208. @RequiresPermissions("sys:user:del")
  209. @RequestMapping(value = "deleteAll")
  210. public AjaxJson deleteAll(String ids) {
  211. String idArray[] = ids.split(",");
  212. AjaxJson j = new AjaxJson();
  213. if (Global.isDemoMode()) {
  214. j.setSuccess(false);
  215. j.setMsg("演示模式,不允许操作!");
  216. return j;
  217. }
  218. for (String id : idArray) {
  219. User user = systemService.getUser(id);
  220. if (UserUtils.getUser().getId().equals(user.getId())) {
  221. j.setSuccess(false);
  222. j.setMsg("删除失败,不允许删除当前用户!");
  223. } else if (User.isAdmin(user.getId())) {
  224. j.setSuccess(false);
  225. j.setMsg("删除失败,不允许删除超级管理员!");//删除用户失败, 不允许删除超级管理员用户
  226. } else {
  227. j.setSuccess(true);
  228. j.setMsg("删除成功!");
  229. systemService.deleteUser(user);//删除用户成功
  230. }
  231. }
  232. return j;
  233. }
  234. /**
  235. * 导出用户数据
  236. *
  237. * @param user
  238. * @param request
  239. * @param response
  240. * @param redirectAttributes
  241. * @return
  242. */
  243. @RequiresPermissions("sys:user:export")
  244. @RequestMapping(value = "export")
  245. public String exportFile(User user, HttpServletRequest request, HttpServletResponse response, RedirectAttributes redirectAttributes) {
  246. try {
  247. String fileName = "用户数据" + DateUtils.getDate("yyyyMMddHHmmss") + ".xlsx";
  248. Page<User> page = systemService.findUser(new Page<User>(request, response, -1), user);
  249. new ExportExcel("用户数据", User.class).setDataList(page.getList()).write(response, fileName).dispose();
  250. return null;
  251. } catch (Exception e) {
  252. addMessage(redirectAttributes, "导出用户失败!失败信息:" + e.getMessage());
  253. }
  254. return "redirect:" + adminPath + "/sys/user/list?repage";
  255. }
  256. /**
  257. * 导入用户数据
  258. *
  259. * @param file
  260. * @param redirectAttributes
  261. * @return
  262. */
  263. @ResponseBody
  264. @RequiresPermissions("sys:user:import")
  265. @RequestMapping(value = "import", method = RequestMethod.POST)
  266. public AjaxJson importFile(MultipartFile file, RedirectAttributes redirectAttributes) {
  267. AjaxJson j = new AjaxJson();
  268. if (Global.isDemoMode()) {
  269. j.setSuccess(false);
  270. j.setMsg("演示模式,不允许操作!");
  271. return j;
  272. }
  273. try {
  274. int successNum = 0;
  275. int failureNum = 0;
  276. StringBuilder failureMsg = new StringBuilder();
  277. ImportExcel ei = new ImportExcel(file, 1, 0);
  278. List<User> list = ei.getDataList(User.class);
  279. for (User user : list) {
  280. try {
  281. if ("true".equals(checkLoginName("", user.getLoginName()))) {
  282. user.setPassword(SystemService.entryptPassword("123456"));
  283. BeanValidators.validateWithException(validator, user);
  284. systemService.saveUser(user);
  285. successNum++;
  286. } else {
  287. failureMsg.append("<br/>登录名 " + user.getLoginName() + " 已存在; ");
  288. failureNum++;
  289. }
  290. } catch (ConstraintViolationException ex) {
  291. failureMsg.append("<br/>登录名 " + user.getLoginName() + " 导入失败:");
  292. List<String> messageList = BeanValidators.extractPropertyAndMessageAsList(ex, ": ");
  293. for (String message : messageList) {
  294. failureMsg.append(message + "; ");
  295. failureNum++;
  296. }
  297. } catch (Exception ex) {
  298. failureMsg.append("<br/>登录名 " + user.getLoginName() + " 导入失败:" + ex.getMessage());
  299. }
  300. }
  301. if (failureNum > 0) {
  302. failureMsg.insert(0, ",失败 " + failureNum + " 条用户,导入信息如下:");
  303. }
  304. j.setMsg("已成功导入 " + successNum + " 条用户" + failureMsg);
  305. } catch (Exception e) {
  306. j.setSuccess(false);
  307. j.setMsg("导入用户失败!失败信息:" + e.getMessage());
  308. }
  309. return j;
  310. }
  311. /**
  312. * 下载导入用户数据模板
  313. *
  314. * @param response
  315. * @param redirectAttributes
  316. * @return
  317. */
  318. @RequiresPermissions("sys:user:import")
  319. @RequestMapping(value = "import/template")
  320. public String importFileTemplate(HttpServletResponse response, RedirectAttributes redirectAttributes) {
  321. try {
  322. String fileName = "用户数据导入模板.xlsx";
  323. List<User> list = Lists.newArrayList();
  324. list.add(UserUtils.getUser());
  325. new ExportExcel("用户数据", User.class, 2).setDataList(list).write(response, fileName).dispose();
  326. return null;
  327. } catch (Exception e) {
  328. addMessage(redirectAttributes, "导入模板下载失败!失败信息:" + e.getMessage());
  329. }
  330. return "redirect:" + adminPath + "/sys/user/list?repage";
  331. }
  332. /**
  333. * 验证登录名是否有效
  334. *
  335. * @param oldLoginName
  336. * @param loginName
  337. * @return
  338. */
  339. @ResponseBody
  340. @RequiresPermissions(value = {"sys:user:add", "sys:user:edit"}, logical = Logical.OR)
  341. @RequestMapping(value = "checkLoginName")
  342. public String checkLoginName(String oldLoginName, String loginName) {
  343. if (loginName != null && loginName.equals(oldLoginName)) {
  344. return "true";
  345. } else if (loginName != null && systemService.getUserByLoginName(loginName) == null) {
  346. return "true";
  347. }
  348. return "false";
  349. }
  350. /**
  351. * 用户信息显示
  352. *
  353. * @param user
  354. * @param model
  355. * @return
  356. */
  357. @RequiresPermissions("user")
  358. @RequestMapping(value = "info")
  359. public String info(HttpServletResponse response, Model model) {
  360. User currentUser = UserUtils.getUser();
  361. model.addAttribute("user", currentUser);
  362. model.addAttribute("Global", new Global());
  363. return "modules/sys/user/userInfo";
  364. }
  365. /**
  366. * 用户信息显示编辑保存
  367. *
  368. * @param user
  369. * @param model
  370. * @return
  371. */
  372. @RequiresPermissions("user")
  373. @RequestMapping(value = "infoEdit")
  374. public String infoEdit(User user, boolean __ajax, HttpServletResponse response, Model model) {
  375. User currentUser = UserUtils.getUser();
  376. if (StringUtils.isNotBlank(user.getName())) {
  377. if (Global.isDemoMode()) {
  378. model.addAttribute("message", "演示模式,不允许操作!");
  379. return "modules/sys/user/userInfo";
  380. }
  381. if (user.getName() != null)
  382. currentUser.setName(user.getName());
  383. if (user.getEmail() != null)
  384. currentUser.setEmail(user.getEmail());
  385. if (user.getPhone() != null)
  386. currentUser.setPhone(user.getPhone());
  387. if (user.getMobile() != null)
  388. currentUser.setMobile(user.getMobile());
  389. if (user.getRemarks() != null)
  390. currentUser.setRemarks(user.getRemarks());
  391. // if(user.getPhoto() !=null )
  392. // currentUser.setPhoto(user.getPhoto());
  393. systemService.updateUserInfo(currentUser);
  394. if (__ajax) {//手机访问
  395. AjaxJson j = new AjaxJson();
  396. j.setSuccess(true);
  397. j.setMsg("修改个人资料成功!");
  398. return renderString(response, j);
  399. }
  400. model.addAttribute("user", currentUser);
  401. model.addAttribute("Global", new Global());
  402. model.addAttribute("message", "保存用户信息成功");
  403. return "modules/sys/user/userInfo";
  404. }
  405. model.addAttribute("user", currentUser);
  406. model.addAttribute("Global", new Global());
  407. return "modules/sys/user/userInfoEdit";
  408. }
  409. /**
  410. * 用户头像显示编辑保存
  411. *
  412. * @param user
  413. * @param model
  414. * @return
  415. */
  416. @RequiresPermissions("user")
  417. @RequestMapping(value = "imageEdit")
  418. public String imageEdit(User user, boolean __ajax, HttpServletResponse response, Model model) {
  419. User currentUser = UserUtils.getUser();
  420. if (StringUtils.isNotBlank(user.getName())) {
  421. if (Global.isDemoMode()) {
  422. model.addAttribute("message", "演示模式,不允许操作!");
  423. return "modules/sys/user/userInfo";
  424. }
  425. if (user.getPhoto() != null)
  426. currentUser.setPhoto(user.getPhoto());
  427. systemService.updateUserInfo(currentUser);
  428. if (__ajax) {//手机访问
  429. AjaxJson j = new AjaxJson();
  430. j.setSuccess(true);
  431. j.setMsg("修改个人头像成功!");
  432. return renderString(response, j);
  433. }
  434. model.addAttribute("message", "保存用户信息成功");
  435. return "modules/sys/user/userInfo";
  436. }
  437. model.addAttribute("user", currentUser);
  438. model.addAttribute("Global", new Global());
  439. return "modules/sys/user/userImageEdit";
  440. }
  441. /**
  442. * 用户头像显示编辑保存
  443. *
  444. * @param user
  445. * @param model
  446. * @return
  447. * @throws IOException
  448. * @throws IllegalStateException
  449. */
  450. @RequiresPermissions("user")
  451. @RequestMapping(value = "imageUpload")
  452. public String imageUpload(HttpServletRequest request, HttpServletResponse response, MultipartFile file) throws IllegalStateException, IOException {
  453. User currentUser = UserUtils.getUser();
  454. // 判断文件是否为空
  455. if (!file.isEmpty()) {
  456. // 文件保存路径
  457. String realPath = Global.getAttachmentDir() + "sys/user/images/";
  458. // 转存文件
  459. FileUtils.createDirectory(realPath);
  460. file.transferTo(new File(realPath + file.getOriginalFilename()));
  461. currentUser.setPhoto(Global.getAttachmentUrl() + "sys/user/images/" + file.getOriginalFilename());
  462. systemService.updateUserInfo(currentUser);
  463. }
  464. return "modules/sys/user/userImageEdit";
  465. }
  466. /**
  467. * 返回用户信息
  468. *
  469. * @return
  470. */
  471. @RequiresPermissions("user")
  472. @ResponseBody
  473. @RequestMapping(value = "infoData")
  474. public AjaxJson infoData() {
  475. AjaxJson j = new AjaxJson();
  476. j.setSuccess(true);
  477. j.setErrorCode("-1");
  478. j.setMsg("获取个人信息成功!");
  479. j.put("data", UserUtils.getUser());
  480. return j;
  481. }
  482. /**
  483. * 修改个人用户密码
  484. *
  485. * @param oldPassword
  486. * @param newPassword
  487. * @param model
  488. * @return
  489. */
  490. @RequiresPermissions("user")
  491. @RequestMapping(value = "modifyPwd")
  492. public String modifyPwd(String oldPassword, String newPassword, Model model) {
  493. return "modules/sys/user/userModifyPwd";
  494. }
  495. @ResponseBody
  496. @RequiresPermissions("user")
  497. @RequestMapping(value = "savePwd")
  498. public AjaxJson savePwd(String oldPassword, String newPassword, Model model) {
  499. AjaxJson j = new AjaxJson();
  500. User user = UserUtils.getUser();
  501. if (StringUtils.isNotBlank(oldPassword) && StringUtils.isNotBlank(newPassword)) {
  502. if (Global.isDemoMode()) {
  503. j.setSuccess(false);
  504. j.setMsg("演示模式,不允许操作!");
  505. return j;
  506. }
  507. if (SystemService.validatePassword(oldPassword, user.getPassword())) {
  508. systemService.updatePasswordById(user.getId(), user.getLoginName(), newPassword);
  509. j.setSuccess(true);
  510. j.setMsg("修改密码成功!");
  511. return j;
  512. } else {
  513. j.setSuccess(false);
  514. j.setMsg("修改密码失败,旧密码错误!");
  515. return j;
  516. }
  517. }
  518. j.setSuccess(false);
  519. j.setMsg("参数错误!");
  520. return j;
  521. }
  522. /**
  523. * 保存签名
  524. */
  525. @ResponseBody
  526. @RequestMapping(value = "saveSign")
  527. public AjaxJson saveSign(User user, boolean __ajax, HttpServletResponse response, Model model) throws Exception {
  528. AjaxJson j = new AjaxJson();
  529. User currentUser = UserUtils.getUser();
  530. currentUser.setSign(user.getSign());
  531. systemService.updateUserInfo(currentUser);
  532. j.setMsg("设置签名成功");
  533. return j;
  534. }
  535. @RequiresPermissions("user")
  536. @ResponseBody
  537. @RequestMapping(value = "treeData")
  538. public List<Map<String, Object>> treeData(@RequestParam(required = false) String officeId, HttpServletResponse response) {
  539. List<Map<String, Object>> mapList = Lists.newArrayList();
  540. List<User> list = systemService.findUserByOfficeId(officeId);
  541. for (int i = 0; i < list.size(); i++) {
  542. User e = list.get(i);
  543. Map<String, Object> map = Maps.newHashMap();
  544. map.put("id", "u_" + e.getId());
  545. map.put("pId", officeId);
  546. map.put("name", StringUtils.replace(e.getName(), " ", ""));
  547. mapList.add(map);
  548. }
  549. return mapList;
  550. }
  551. /**
  552. * web端ajax验证用户名是否可用
  553. *
  554. * @param loginName
  555. * @param response
  556. * @return
  557. */
  558. @ResponseBody
  559. @RequestMapping(value = "validateLoginName")
  560. public boolean validateLoginName(String loginName, HttpServletResponse response) {
  561. User user = userMapper.findUniqueByProperty("login_name", loginName);
  562. if (user == null) {
  563. return true;
  564. } else {
  565. return false;
  566. }
  567. }
  568. /**
  569. * web端ajax验证手机号是否可以注册(数据库中不存在)
  570. */
  571. @ResponseBody
  572. @RequestMapping(value = "validateMobile")
  573. public boolean validateMobile(String mobile, HttpServletResponse response, Model model) {
  574. User user = userMapper.findUniqueByProperty("mobile", mobile);
  575. if (user == null) {
  576. return true;
  577. } else {
  578. return false;
  579. }
  580. }
  581. /**
  582. * web端ajax验证手机号是否已经注册(数据库中已存在)
  583. */
  584. @ResponseBody
  585. @RequestMapping(value = "validateMobileExist")
  586. public boolean validateMobileExist(String mobile, HttpServletResponse response, Model model) {
  587. User user = userMapper.findUniqueByProperty("mobile", mobile);
  588. if (user != null) {
  589. return true;
  590. } else {
  591. return false;
  592. }
  593. }
  594. @ResponseBody
  595. @RequestMapping(value = "resetPassword")
  596. public AjaxJson resetPassword(String mobile, HttpServletResponse response, Model model) {
  597. SystemConfig config = systemConfigService.get("1");//获取短信配置的用户名和密码
  598. AjaxJson j = new AjaxJson();
  599. if (userMapper.findUniqueByProperty("mobile", mobile) == null) {
  600. j.setSuccess(false);
  601. j.setMsg("手机号不存在!");
  602. j.setErrorCode("1");
  603. return j;
  604. }
  605. User user = userMapper.findUniqueByProperty("mobile", mobile);
  606. String newPassword = String.valueOf((int) (Math.random() * 900000 + 100000));
  607. try {
  608. String result = UserUtils.sendPass(config.getSmsName(), config.getSmsPassword(), mobile, newPassword);
  609. if (!result.equals("100")) {
  610. j.setSuccess(false);
  611. j.setErrorCode("2");
  612. j.setMsg("短信发送失败,密码重置失败,错误代码:" + result + ",请联系管理员。");
  613. } else {
  614. j.setSuccess(true);
  615. j.setErrorCode("-1");
  616. j.setMsg("短信发送成功,密码重置成功!");
  617. systemService.updatePasswordById(user.getId(), user.getLoginName(), newPassword);
  618. }
  619. } catch (IOException e) {
  620. j.setSuccess(false);
  621. j.setErrorCode("3");
  622. j.setMsg("因未知原因导致短信发送失败,请联系管理员。");
  623. }
  624. return j;
  625. }
  626. }