SysLoginController.java 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /**
  2. * Copyright (c) 2016-2019 人人开源 All rights reserved.
  3. * <p>
  4. * https://www.renren.io
  5. * <p>
  6. * 版权所有,侵权必究!
  7. */
  8. package io.renren.modules.sys.controller;
  9. import io.renren.common.annotation.SysLog;
  10. import io.renren.common.utils.HttpContextUtils;
  11. import io.renren.common.utils.IPUtils;
  12. import io.renren.common.utils.R;
  13. import io.renren.modules.sys.entity.SysLogEntity;
  14. import io.renren.modules.sys.entity.SysUserEntity;
  15. import io.renren.modules.sys.form.SysLoginForm;
  16. import io.renren.modules.sys.service.SysCaptchaService;
  17. import io.renren.modules.sys.service.SysLogService;
  18. import io.renren.modules.sys.service.SysUserService;
  19. import io.renren.modules.sys.service.SysUserTokenService;
  20. import org.apache.commons.io.IOUtils;
  21. import org.apache.shiro.crypto.hash.Sha256Hash;
  22. import org.springframework.beans.factory.annotation.Autowired;
  23. import org.springframework.web.bind.annotation.*;
  24. import javax.imageio.ImageIO;
  25. import javax.servlet.ServletOutputStream;
  26. import javax.servlet.http.HttpServletRequest;
  27. import javax.servlet.http.HttpServletResponse;
  28. import java.awt.image.BufferedImage;
  29. import java.io.Console;
  30. import java.io.IOException;
  31. import java.util.Date;
  32. import java.util.Map;
  33. /**
  34. * 登录相关
  35. *
  36. * @author Mark 735032128@qq.com
  37. */
  38. @RestController
  39. public class SysLoginController extends AbstractController {
  40. @Autowired
  41. private SysUserService sysUserService;
  42. @Autowired
  43. private SysUserTokenService sysUserTokenService;
  44. @Autowired
  45. private SysCaptchaService sysCaptchaService;
  46. @Autowired
  47. private SysLogService sysLogService;
  48. /**
  49. * 验证码
  50. */
  51. @GetMapping("captcha.jpg")
  52. public void captcha(HttpServletResponse response, String uuid) throws IOException {
  53. response.setHeader("Cache-Control", "no-store, no-cache");
  54. response.setContentType("image/jpeg");
  55. //获取图片验证码
  56. BufferedImage image = sysCaptchaService.getCaptcha(uuid);
  57. ServletOutputStream out = response.getOutputStream();
  58. ImageIO.write(image, "jpg", out);
  59. IOUtils.closeQuietly(out);
  60. }
  61. /**
  62. * 登录
  63. */
  64. @PostMapping("/sys/login")
  65. public Map<String, Object> login(@RequestBody SysLoginForm form) throws IOException {
  66. /*boolean captcha = sysCaptchaService.validate(form.getUuid(), form.getCaptcha());
  67. if (!form.getCaptcha().equals("8888")) {
  68. if (!captcha) {
  69. return R.error("验证码不正确");
  70. }
  71. }*/
  72. //用户信息
  73. SysUserEntity user = sysUserService.queryByUserName(form.getUsername());
  74. //账号不存在、密码错误
  75. if (user == null || !user.getPassword().equals(new Sha256Hash(form.getPassword(), user.getSalt()).toHex())) {
  76. return R.error("账号或密码不正确");
  77. }
  78. //账号锁定
  79. if (user.getStatus() == 0) {
  80. return R.error("账号已被锁定,请联系管理员");
  81. }
  82. //生成token,并保存到数据库
  83. R r = sysUserTokenService.createToken(user.getUserId());
  84. //
  85. SysLogEntity sysLog = new SysLogEntity();
  86. //获取request
  87. HttpServletRequest request = HttpContextUtils.getHttpServletRequest();
  88. //设置IP地址
  89. sysLog.setIp(IPUtils.getIpAddr(request));
  90. //用户名
  91. sysLog.setUsername(user.getUsername());
  92. sysLog.setCreateDate(new Date());
  93. sysLog.setTime(0l);
  94. sysLog.setOperation("登录");
  95. //保存系统日志
  96. sysLogService.save(sysLog);
  97. return r;
  98. }
  99. /**
  100. * 退出
  101. */
  102. @PostMapping("/sys/logout")
  103. public R logout() {
  104. sysUserTokenService.logout(getUserId());
  105. return R.ok();
  106. }
  107. }