MemberSysAccessTokenRefreshTask.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package com.kmall.admin.haikong.task;
  2. import com.fasterxml.jackson.core.type.TypeReference;
  3. import com.kmall.admin.haikong.client.HaiKongMemberTemplate;
  4. import com.kmall.admin.haikong.constant.Constants;
  5. import com.kmall.admin.haikong.dto.AccessTokenDTO;
  6. import com.kmall.admin.haikong.utils.Response;
  7. import com.kmall.admin.utils.jackson.JacksonUtil;
  8. import com.kmall.manager.manager.redis.JedisUtil;
  9. import org.slf4j.Logger;
  10. import org.slf4j.LoggerFactory;
  11. import org.springframework.beans.factory.annotation.Autowired;
  12. import org.springframework.scheduling.annotation.Scheduled;
  13. import org.springframework.stereotype.Component;
  14. import org.springframework.util.StringUtils;
  15. import java.io.IOException;
  16. import java.util.Objects;
  17. import java.util.Optional;
  18. /**
  19. * 刷新会员系统token定时任务
  20. * @author lhm
  21. * @createDate 2021-10-30
  22. */
  23. @Component
  24. public class MemberSysAccessTokenRefreshTask {
  25. private static final Logger log = LoggerFactory.getLogger(MemberSysAccessTokenRefreshTask.class);
  26. @Autowired
  27. private HaiKongMemberTemplate haiKongMemberTemplate;
  28. @Scheduled(cron = "0/30 * * * * ?")
  29. public void refresh() {
  30. String refreshToken = JedisUtil.get(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY);
  31. String accessToken = JedisUtil.get(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  32. // if (!StringUtils.isEmpty(refreshToken) && !StringUtils.isEmpty(accessToken)) {
  33. // return;
  34. // }
  35. boolean a = false;
  36. if (StringUtils.isEmpty(refreshToken)) {
  37. try {
  38. log.info("accessToken和refreshToken缓存都为空!开始刷新缓存......");
  39. String accessTokenJson = haiKongMemberTemplate.getAccessToken();
  40. a = true;
  41. handleResponse(accessTokenJson, a);
  42. log.info("accessToken和refreshToken缓存都为空!刷新缓存完成......");
  43. } catch (Exception e) {
  44. log.error(e.getMessage() + "====>", e);
  45. }
  46. } else if (!StringUtils.isEmpty(refreshToken)) {
  47. try {
  48. String refreshAccessTokenJson = haiKongMemberTemplate.refreshAccessToken(refreshToken);
  49. handleResponse(refreshAccessTokenJson, a);
  50. } catch (Exception e) {
  51. log.error(e.getMessage() + "====>", e);
  52. }
  53. }
  54. }
  55. private void handleResponse(String json, Boolean a) {
  56. Response<AccessTokenDTO> response = null;
  57. try {
  58. response = JacksonUtil.getObjectMapper().readValue(json, new TypeReference<Response<AccessTokenDTO>>() {
  59. });
  60. } catch (IOException e) {
  61. log.error("解析海控会员系统响应结果失败!", e);
  62. return;
  63. }
  64. if (Objects.nonNull(response) && response.getSuccess()) {
  65. AccessTokenDTO accessTokenDTO = response.getData();
  66. JedisUtil.del(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  67. JedisUtil.set(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY, JacksonUtil.toJson(accessTokenDTO), (60 * 60 * 2) - (60 * 10));
  68. if (a) {
  69. JedisUtil.del(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY);
  70. JedisUtil.set(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY, Optional.ofNullable(accessTokenDTO.getRefreshToken()).orElse(""), (60 * 60 * 24 * 7));
  71. }
  72. } else if (Objects.nonNull(response) && !response.getSuccess() && Response.ErrorCodeEnum.INVALID_REFRESH.getErrorCode().equals(response.getErrorCode())) {
  73. log.info("海控会员系统RefreshToken已失效,重新获取AccessToken与RefreshToken!");
  74. JedisUtil.del(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY);
  75. refresh();
  76. } else {
  77. log.error("请求海控会员系统AccessToken返回响应为空!");
  78. }
  79. }
  80. public String getAccessToken() throws Exception {
  81. String accessTokenJson = JedisUtil.get(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  82. if (StringUtils.isEmpty(accessTokenJson)) {
  83. refresh();
  84. accessTokenJson = JedisUtil.get(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  85. AccessTokenDTO accessTokenDTO = JacksonUtil.fromStringJson(accessTokenJson, AccessTokenDTO.class);
  86. if (Objects.isNull(accessTokenDTO)) {
  87. log.error("accessToken数据转为对象失败!");
  88. throw new Exception("accessToken数据转为对象失败!");
  89. }
  90. return accessTokenDTO.getAccessToken();
  91. } else {
  92. AccessTokenDTO accessTokenDTO = JacksonUtil.fromStringJson(accessTokenJson, AccessTokenDTO.class);
  93. if (Objects.isNull(accessTokenDTO)) {
  94. log.error("accessToken数据转为对象失败!");
  95. throw new Exception("accessToken数据转为对象失败!");
  96. }
  97. return accessTokenDTO.getAccessToken();
  98. }
  99. }
  100. }