SysLoginController.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package com.hz.web.controller.system;
  2. import java.util.*;
  3. import java.util.concurrent.TimeUnit;
  4. import com.alibaba.fastjson.JSON;
  5. import com.alibaba.fastjson.JSONObject;
  6. import com.hz.common.core.redis.RedisCache;
  7. import com.hz.common.core.text.Convert;
  8. import com.hz.common.utils.StringUtils;
  9. import com.hz.common.utils.http.HttpUtils;
  10. import io.swagger.annotations.Api;
  11. import io.swagger.annotations.ApiOperation;
  12. import lombok.extern.slf4j.Slf4j;
  13. import org.springframework.beans.factory.annotation.Value;
  14. import org.springframework.web.bind.annotation.GetMapping;
  15. import org.springframework.web.bind.annotation.PostMapping;
  16. import org.springframework.web.bind.annotation.RequestBody;
  17. import org.springframework.web.bind.annotation.RestController;
  18. import com.hz.common.constant.Constants;
  19. import com.hz.common.core.domain.AjaxResult;
  20. import com.hz.common.core.domain.entity.SysMenu;
  21. import com.hz.common.core.domain.entity.SysUser;
  22. import com.hz.common.core.domain.model.LoginBody;
  23. import com.hz.common.core.domain.model.LoginUser;
  24. import com.hz.common.utils.SecurityUtils;
  25. import com.hz.common.utils.ServletUtils;
  26. import com.hz.framework.web.service.SysLoginService;
  27. import com.hz.framework.web.service.SysPermissionService;
  28. import com.hz.framework.web.service.TokenService;
  29. import com.hz.system.service.ISysMenuService;
  30. import org.springframework.web.client.RestTemplate;
  31. import javax.annotation.Resource;
  32. import javax.servlet.http.HttpServletRequest;
  33. /**
  34. * 登录验证
  35. *
  36. * @author user
  37. */
  38. @Slf4j
  39. @Api(tags = "登录验证")
  40. @RestController
  41. public class SysLoginController {
  42. // 字节私有云地址
  43. final static String PRE_URL = "https://ve-portal.chehezhi.cn";
  44. @Resource
  45. private SysLoginService loginService;
  46. @Resource
  47. private ISysMenuService menuService;
  48. @Resource
  49. private SysPermissionService permissionService;
  50. @Resource
  51. private TokenService tokenService;
  52. @Value("${qyapi.corpid}")
  53. private String corpId;
  54. @Value("${qyapi.corpsecret}")
  55. private String corpSecret;
  56. @Resource
  57. private RedisCache redisCache;
  58. /**
  59. * 登录方法
  60. *
  61. * @param loginBody 登录信息
  62. * @return 结果
  63. */
  64. @ApiOperation("登录方法")
  65. @PostMapping("/login")
  66. public AjaxResult login(@RequestBody LoginBody loginBody) throws Exception {
  67. AjaxResult ajax = AjaxResult.success();
  68. String token = loginService.login(loginBody);
  69. ajax.put(Constants.TOKEN, token);
  70. // ajax.put("jwtToken", loginJwtToken());
  71. return ajax;
  72. }
  73. /**
  74. * 企业微信登录
  75. *
  76. * @param
  77. * @return java.lang.String
  78. */
  79. public String updateAccessToken() {
  80. String accessTokenValue = Convert.toStr(redisCache.getCacheObject("qywx-token"));
  81. String param = "corpid=" + corpId + "&corpsecret=" + corpSecret;
  82. String response = HttpUtils.sendGet("TOKEN_URL", param, "UTF-8");
  83. com.hz.common.core.domain.QyResponse qyResponse = JSON.parseObject(response, com.hz.common.core.domain.QyResponse.class);
  84. if (StringUtils.isEmpty(accessTokenValue) || !qyResponse.getAccessToken().equals(accessTokenValue)) {
  85. if (qyResponse.getErrCode() != null && qyResponse.getErrCode() == 0) {
  86. //token 一个小时过期
  87. redisCache.setCacheObject("qywx-token", qyResponse.getAccessToken());
  88. redisCache.expire("qywx-token", 1, TimeUnit.HOURS);
  89. return qyResponse.getAccessToken();
  90. }
  91. }
  92. return accessTokenValue;
  93. }
  94. /**
  95. * 获取用户信息
  96. *
  97. * @return 用户信息
  98. */
  99. @ApiOperation("获取用户信息")
  100. @GetMapping("getInfo")
  101. public AjaxResult getInfo() {
  102. LoginUser loginUser = tokenService.getLoginUser(ServletUtils.getRequest());
  103. SysUser user = loginUser.getUser();
  104. // 角色集合
  105. Set<String> roles = permissionService.getRolePermission(user);
  106. // 权限集合
  107. Set<String> permissions = permissionService.getMenuPermission(user);
  108. AjaxResult ajax = AjaxResult.success();
  109. ajax.put("user", user);
  110. ajax.put("roles", roles);
  111. ajax.put("permissions", permissions);
  112. return ajax;
  113. }
  114. /**
  115. * 获取路由信息
  116. *
  117. * @return 路由信息
  118. */
  119. @ApiOperation("获取路由信息")
  120. @GetMapping("getRouters")
  121. public AjaxResult getRouters() {
  122. Long userId = SecurityUtils.getUserId();
  123. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  124. return AjaxResult.success(menuService.buildMenus(menus));
  125. }
  126. }