LoginApi.java 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package com.caimei.controller.wechat;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.caimei.model.ResponseJson;
  4. import com.caimei.model.vo.WxClubUserVo;
  5. import com.caimei.service.wechat.LoginService;
  6. import com.caimei.utils.HttpRequest;
  7. import io.swagger.annotations.Api;
  8. import io.swagger.annotations.ApiImplicitParam;
  9. import io.swagger.annotations.ApiOperation;
  10. import lombok.RequiredArgsConstructor;
  11. import org.apache.commons.lang3.StringUtils;
  12. import org.springframework.web.bind.annotation.*;
  13. import javax.servlet.http.HttpServletRequest;
  14. /**
  15. * 微信机构用户登录API
  16. *
  17. * @author : Aslee
  18. * @date : 2021/5/11
  19. */
  20. @Api(tags = "微信机构用户登录API")
  21. @RestController
  22. @RequiredArgsConstructor
  23. @RequestMapping("/wx/user/login")
  24. public class LoginApi {
  25. private final LoginService loginService;
  26. @ApiOperation("服务号授权登录")
  27. @ApiImplicitParam(name = "params", value = "code登录凭证;appId;", required = true)
  28. @PostMapping("/authorization")
  29. public ResponseJson<WxClubUserVo> authorizationLogin(@RequestBody String params) {
  30. JSONObject parseObject = JSONObject.parseObject(params);
  31. String code = parseObject.getString("code");
  32. String appId = parseObject.getString("appId");
  33. return loginService.loginByAuthorization(code, appId);
  34. }
  35. @ApiOperation("登录验证码发送")
  36. @ApiImplicitParam(name = "params", value = "mobile:手机号;appId:公众号appId;type:1订阅号验证码,2服务号验证码", required = true)
  37. @PostMapping("/verify/code/send")
  38. public ResponseJson sendVerifyCode(@RequestBody String params) {
  39. JSONObject parseObject = JSONObject.parseObject(params);
  40. String mobile = parseObject.getString("mobile");
  41. Integer authUserId = parseObject.getInteger("authUserId");
  42. Integer type = parseObject.getInteger("type");
  43. return loginService.sendVerifyCode(mobile, authUserId, type);
  44. }
  45. @ApiOperation("服务号验证码登录")
  46. @ApiImplicitParam(name = "params", value = "mobile:手机号;verifyCode:验证码;invitationCode:邀请码;accessToken;openId;appId", required = true)
  47. @PostMapping("/service/invitation/code")
  48. public ResponseJson<WxClubUserVo> invitationCode(@RequestBody String params) throws Exception {
  49. JSONObject parseObject = JSONObject.parseObject(params);
  50. String mobile = parseObject.getString("mobile");
  51. String verifyCode = parseObject.getString("verifyCode");
  52. String accessToken = parseObject.getString("accessToken");
  53. String openId = parseObject.getString("openId");
  54. String appId = parseObject.getString("appId");
  55. return loginService.loginByVerifyCode(mobile, verifyCode, accessToken, openId, appId);
  56. }
  57. @ApiOperation("订阅号验证码登录")
  58. @ApiImplicitParam(name = "params", value = "mobile:手机号;verifyCode:验证码;openId;appId", required = true)
  59. @PostMapping("/subscribe/verify/code")
  60. public ResponseJson<WxClubUserVo> loginByVerifyCode(@RequestBody String params){
  61. JSONObject parseObject = JSONObject.parseObject(params);
  62. String mobile = parseObject.getString("mobile");
  63. String verifyCode = parseObject.getString("verifyCode");
  64. Integer authUserId = parseObject.getInteger("authUserId");
  65. return loginService.loginByVerifyCode(mobile, verifyCode, authUserId);
  66. }
  67. @ApiOperation("密码登录")
  68. @ApiImplicitParam(name = "params", value = "mobile:手机号;password:密码;authUserId:供应商用户id", required = true)
  69. @PostMapping("/password")
  70. public ResponseJson<WxClubUserVo> passwordLogin(@RequestBody String params) {
  71. JSONObject parseObject = JSONObject.parseObject(params);
  72. String mobile = parseObject.getString("mobile");
  73. String password = parseObject.getString("password");
  74. Integer authUserId = parseObject.getInteger("authUserId");
  75. if (StringUtils.isEmpty(mobile) || StringUtils.isEmpty(password)) {
  76. return ResponseJson.error("参数异常", null);
  77. }
  78. if (null == authUserId) {
  79. return ResponseJson.error("供应商用户id不能为空", null);
  80. }
  81. return loginService.passwordLogin(mobile, password, authUserId);
  82. }
  83. @ApiOperation("根据token获取用户信息")
  84. @GetMapping("/token/check")
  85. public ResponseJson<WxClubUserVo> getUserInfoByToken(HttpServletRequest httpRequest) {
  86. return loginService.getUserInfoByToken(httpRequest);
  87. }
  88. }