SysLoginController.java 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. package com.ruoyi.web.controller.system;
  2. import com.alibaba.fastjson2.JSONObject;
  3. import com.ruoyi.common.config.WxAppConfig;
  4. import com.ruoyi.common.constant.Constants;
  5. import com.ruoyi.common.core.domain.AjaxResult;
  6. import com.ruoyi.common.core.domain.entity.SysMenu;
  7. import com.ruoyi.common.core.domain.entity.SysUser;
  8. import com.ruoyi.common.core.domain.model.LoginBody;
  9. import com.ruoyi.common.core.domain.model.LoginByTelephoneBody;
  10. import com.ruoyi.common.core.domain.model.WxLoginBody;
  11. import com.ruoyi.common.utils.SecurityUtils;
  12. import com.ruoyi.common.utils.StringUtils;
  13. import com.ruoyi.common.utils.sign.Base64;
  14. import com.ruoyi.framework.web.service.SysLoginService;
  15. import com.ruoyi.framework.web.service.SysPermissionService;
  16. import com.ruoyi.system.service.ISysMenuService;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.web.bind.annotation.*;
  19. import javax.crypto.Cipher;
  20. import javax.crypto.spec.IvParameterSpec;
  21. import javax.crypto.spec.SecretKeySpec;
  22. import java.lang.reflect.Array;
  23. import java.security.spec.AlgorithmParameterSpec;
  24. import java.util.Arrays;
  25. import java.util.List;
  26. import java.util.Set;
  27. import org.springframework.web.client.RestTemplate;
  28. /**
  29. * 登录验证
  30. *
  31. * @author ruoyi
  32. */
  33. @RestController
  34. public class SysLoginController {
  35. @Autowired
  36. private SysLoginService loginService;
  37. @Autowired
  38. private ISysMenuService menuService;
  39. @Autowired
  40. private SysPermissionService permissionService;
  41. /**
  42. * 登录方法
  43. *
  44. * @param loginBody 登录信息
  45. * @return 结果
  46. */
  47. @PostMapping("/login")
  48. public AjaxResult login(@RequestBody LoginBody loginBody) {
  49. AjaxResult ajax = AjaxResult.success();
  50. // 生成令牌
  51. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  52. loginBody.getUuid(), false);
  53. ajax.put(Constants.TOKEN, token);
  54. return ajax;
  55. }
  56. @Autowired
  57. private WxAppConfig wxAppConfig;
  58. @RequestMapping("/wxLogin")
  59. public AjaxResult wxLogin(@RequestBody WxLoginBody wxLoginBody) {
  60. String code = wxLoginBody.getCode();
  61. //向微信服务器发送请求获取用户信息
  62. String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + wxAppConfig.getAppId() + "&secret=" + wxAppConfig.getAppSecret() + "&code=" + code + "&grant_type=authorization_code";
  63. final RestTemplate restTemplate = new RestTemplate();
  64. String res = restTemplate.getForObject(url, String.class);
  65. System.out.println("res:" + res);
  66. JSONObject jsonObject = JSONObject.parseObject(res);
  67. // 判断JSON对象中 是否存在 错误代码
  68. if (jsonObject.containsKey("errcode")) {
  69. // 返回错误代码
  70. return AjaxResult.error(jsonObject.getString("errcode"));
  71. }
  72. // 获取 unionid
  73. String unionid = jsonObject.getString("unionid");
  74. // 获取 openId
  75. String openid = jsonObject.getString("openid");
  76. // 获取 accessToken
  77. String accessToken = jsonObject.getString("access_token");
  78. //向微信服务器发送请求获取用户信息
  79. url = "https://api.weixin.qq.com/sns/userinfo?access_token=" + accessToken + "&openid==" + openid + "&grant_type=authorization_code";
  80. res = restTemplate.getForObject(url, String.class);
  81. System.out.println("res:" + res);
  82. jsonObject = JSONObject.parseObject(res);
  83. // 判断JSON对象中 是否存在 错误代码
  84. if (jsonObject.containsKey("errcode")) {
  85. // 返回错误代码
  86. return AjaxResult.error(jsonObject.getString("errcode"));
  87. }
  88. // 获取 province
  89. //String province= jsonObject.getString("province");
  90. // 获取 nickname
  91. String nickname = jsonObject.getString("nickname");
  92. // 获取 headimgurl
  93. String headimgurl = jsonObject.getString("headimgurl");
  94. String[] result = {openid,nickname,headimgurl};
  95. String token = loginService.wxLogin(result);
  96. AjaxResult ajax = AjaxResult.success();
  97. ajax.put(Constants.TOKEN, token);
  98. return ajax;
  99. }
  100. /**
  101. * 登录方法
  102. *
  103. * @param loginBody 登录信息
  104. * @return 结果
  105. */
  106. @PostMapping("/loginCommunity")
  107. public AjaxResult loginCommunity(@RequestBody LoginBody loginBody) {
  108. AjaxResult ajax = AjaxResult.success();
  109. // 生成令牌
  110. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  111. loginBody.getUuid(), true);
  112. ajax.put(Constants.TOKEN, token);
  113. return ajax;
  114. }
  115. /**
  116. * 获取用户信息
  117. *
  118. * @return 用户信息
  119. */
  120. @GetMapping("getInfo")
  121. public AjaxResult getInfo() {
  122. SysUser user = SecurityUtils.getLoginUser().getUser();
  123. // 角色集合
  124. Set<String> roles = permissionService.getRolePermission(user);
  125. // 权限集合
  126. Set<String> permissions = permissionService.getMenuPermission(user);
  127. AjaxResult ajax = AjaxResult.success();
  128. ajax.put("user", user);
  129. ajax.put("roles", roles);
  130. ajax.put("permissions", permissions);
  131. return ajax;
  132. }
  133. /**
  134. * 获取路由信息
  135. *
  136. * @return 路由信息
  137. */
  138. @GetMapping("getRouters")
  139. public AjaxResult getRouters() {
  140. Long userId = SecurityUtils.getUserId();
  141. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  142. return AjaxResult.success(menuService.buildMenus(menus));
  143. }
  144. @PostMapping("/phoneLogin")
  145. public AjaxResult phoneLogin(@RequestBody LoginByTelephoneBody loginBody){
  146. AjaxResult ajax = AjaxResult.success();
  147. // 生成令牌
  148. String token = loginService.loginByTelephone(loginBody.getUsername(), loginBody.getCode(),
  149. loginBody.getUuid());
  150. ajax.put(Constants.TOKEN, token);
  151. return ajax;
  152. }
  153. }