LoginApi.java 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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 io.swagger.annotations.Api;
  7. import io.swagger.annotations.ApiImplicitParam;
  8. import io.swagger.annotations.ApiOperation;
  9. import lombok.RequiredArgsConstructor;
  10. import org.springframework.web.bind.annotation.PostMapping;
  11. import org.springframework.web.bind.annotation.RequestBody;
  12. import org.springframework.web.bind.annotation.RequestMapping;
  13. import org.springframework.web.bind.annotation.RestController;
  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")
  24. public class LoginApi {
  25. private final LoginService loginService;
  26. @ApiOperation("服务号授权登录")
  27. @ApiImplicitParam(name = "params", value = "code登录凭证;appId;", required = true)
  28. @PostMapping("/login/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("/login/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("/login/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. String appId = parseObject.getString("appId");
  65. return loginService.loginByVerifyCode(mobile, verifyCode, appId);
  66. }
  67. @ApiOperation("校验token是否失效")
  68. @PostMapping("/token/check")
  69. public ResponseJson checkToken(){
  70. return ResponseJson.success("token有效");
  71. }
  72. }