WxGzhController.java 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. package com.template.controller;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.Wrapper;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  6. import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
  7. import com.google.gson.Gson;
  8. import com.google.gson.reflect.TypeToken;
  9. import com.template.annotation.DESRespondSecret;
  10. import com.template.annotation.PassToken;
  11. import com.template.api.WxGzhControllerAPI;
  12. import com.template.common.utils.*;
  13. import com.template.model.pojo.SmartCodeOpenId;
  14. import com.template.model.pojo.SmartUser;
  15. import com.template.model.pojo.SmsCode;
  16. import com.template.model.result.CommonResult;
  17. import com.template.model.weixin.HttpParame;
  18. import com.template.services.SmartCodeOpenIdService;
  19. import com.template.services.SmartUserService;
  20. import com.template.services.SmsCodeService;
  21. import org.apache.commons.lang3.StringUtils;
  22. import org.apache.http.HttpResponse;
  23. import org.apache.http.client.HttpClient;
  24. import org.apache.http.client.methods.HttpGet;
  25. import org.apache.http.client.methods.HttpPost;
  26. import org.apache.http.entity.StringEntity;
  27. import org.apache.http.impl.client.HttpClientBuilder;
  28. import org.apache.http.util.EntityUtils;
  29. import org.slf4j.Logger;
  30. import org.slf4j.LoggerFactory;
  31. import org.springframework.beans.factory.annotation.Autowired;
  32. import org.springframework.web.bind.annotation.RestController;
  33. import java.util.Date;
  34. import java.util.HashMap;
  35. import java.util.List;
  36. @RestController
  37. //返回参数加密注解
  38. @DESRespondSecret
  39. public class WxGzhController implements WxGzhControllerAPI {
  40. private static Logger logger = LoggerFactory.getLogger(WxGzhController.class);
  41. // 公众号的唯一标识
  42. private static String appid = "wxa46ef222053a1047";
  43. // 公众号的appsecret
  44. private static String secret = "16f74a1265c314fd79fdf90670173467";
  45. @Autowired
  46. SmartUserService smartUserService;
  47. @Autowired
  48. SmartCodeOpenIdService smartCodeOpenIdService;
  49. @Autowired
  50. SmsCodeService smsCodeService;
  51. @Override
  52. @PassToken
  53. @DESRespondSecret(validated = true)
  54. public CommonResult getWxGzhOpenid(String code) throws Exception {
  55. String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + appid + "&secret=" + secret + "&code=" + code + "&grant_type=authorization_code";
  56. logger.info("url = " + url);
  57. String s = HttpsClient.httpsRequestReturnString(url, "GET", "");
  58. JSONObject jsonObject = JSONObject.parseObject(s);
  59. if (!jsonObject.containsKey("openid")) {
  60. return CommonResult.fail("code有误");
  61. }
  62. String openid = jsonObject.getString("openid");
  63. // 判断openid是否已经存在
  64. LambdaQueryWrapper<SmartUser> wrapper = new LambdaQueryWrapper<>();
  65. wrapper.eq(SmartUser::getGzhOpenId, openid);
  66. SmartUser smartUser = smartUserService.getOne(wrapper);
  67. JSONObject jsonObject1 = new JSONObject();
  68. if (ObjectUtils.isNotEmpty(smartUser)) {
  69. jsonObject1.put("phone", smartUser.getPhone());
  70. return CommonResult.ok(jsonObject1);
  71. }
  72. SmartCodeOpenId smartCodeOpenId = new SmartCodeOpenId();
  73. smartCodeOpenId.setCode(code);
  74. smartCodeOpenId.setOpenId(openid);
  75. smartCodeOpenIdService.save(smartCodeOpenId);
  76. logger.info("openid = " + openid);
  77. jsonObject1.put("phone", "");
  78. return CommonResult.ok(jsonObject1);
  79. }
  80. @Override
  81. @PassToken
  82. @DESRespondSecret(validated = true)
  83. public CommonResult vertifyMessage(String phone, String code, String wxGzhCode) {
  84. QueryWrapper<SmsCode> queryWrapper1 = new QueryWrapper<>();
  85. queryWrapper1.eq("deleted", 0);
  86. queryWrapper1.eq("is_verify", 0);
  87. queryWrapper1.eq("phone_number", phone);
  88. queryWrapper1.isNull("method");
  89. queryWrapper1.eq("code", code);
  90. queryWrapper1.ge("expiration_time", new Date());
  91. List<SmsCode> listc = smsCodeService.getSmsCodeByKey(queryWrapper1);
  92. if (listc.isEmpty()) {
  93. return CommonResult.fail("验证码已失效");
  94. }
  95. for (SmsCode smsCode : listc) {
  96. smsCode.setIsVerify("1");
  97. smsCodeService.updateSmsCode(smsCode);
  98. }
  99. QueryWrapper<SmartUser> queryWrapper2 = new QueryWrapper<>();
  100. queryWrapper2.eq("deleted", 0);
  101. queryWrapper2.eq("phone", phone);
  102. SmartUser user = smartUserService.getOne(queryWrapper2);
  103. if (ObjectUtils.isEmpty(user)) {
  104. return CommonResult.fail("该用户不存在");
  105. }
  106. LambdaQueryWrapper<SmartCodeOpenId> wrapperCode = new LambdaQueryWrapper<>();
  107. wrapperCode.eq(SmartCodeOpenId::getCode, wxGzhCode);
  108. SmartCodeOpenId smartCodeOpenId = smartCodeOpenIdService.getOne(wrapperCode);
  109. if (ObjectUtils.isNotEmpty(smartCodeOpenId)) {
  110. user.setGzhOpenId(smartCodeOpenId.getOpenId());
  111. smartUserService.updateSmartUser(user);
  112. }
  113. return CommonResult.ok();
  114. }
  115. @Override
  116. @PassToken
  117. @DESRespondSecret(validated = true)
  118. public CommonResult unbinding(String phone) {
  119. if (ObjectUtils.isEmpty(phone)) {
  120. return CommonResult.fail("参数异常");
  121. }
  122. QueryWrapper<SmartUser> queryWrapper = new QueryWrapper<>();
  123. queryWrapper.eq("deleted", 0);
  124. queryWrapper.eq("phone", phone);
  125. SmartUser user = smartUserService.getOne(queryWrapper);
  126. if (ObjectUtils.isEmpty(user)) {
  127. return CommonResult.fail("该用户不存在");
  128. }
  129. user.setGzhOpenId("");
  130. smartUserService.updateById(user);
  131. return CommonResult.ok();
  132. }
  133. }