MemberSysAccessTokenRefreshTask.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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 55 0/2 * * ?")
  29. @Scheduled(cron = "0/20 0/2 * * * ?")
  30. public void refresh() {
  31. String refreshToken = JedisUtil.get(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY);
  32. boolean a = false;
  33. if (StringUtils.isEmpty(refreshToken)) {
  34. try {
  35. log.info("accessToken和refreshToken缓存都为空!开始刷新缓存......");
  36. String accessTokenJson = haiKongMemberTemplate.getAccessToken();
  37. a = true;
  38. handleResponse(accessTokenJson, a);
  39. log.info("accessToken和refreshToken缓存都为空!刷新缓存完成......");
  40. } catch (Exception e) {
  41. log.error(e.getMessage() + "====>", e);
  42. }
  43. } else {
  44. try {
  45. String refreshAccessTokenJson = haiKongMemberTemplate.refreshAccessToken(refreshToken);
  46. handleResponse(refreshAccessTokenJson, a);
  47. } catch (Exception e) {
  48. log.error(e.getMessage() + "====>", e);
  49. }
  50. }
  51. }
  52. private void handleResponse(String json, Boolean a) {
  53. Response<AccessTokenDTO> response = null;
  54. try {
  55. response = JacksonUtil.getObjectMapper().readValue(json, new TypeReference<Response<AccessTokenDTO>>() {
  56. });
  57. } catch (IOException e) {
  58. log.error("解析海控会员系统响应结果失败!", e);
  59. return;
  60. }
  61. if (Objects.nonNull(response) && response.getSuccess()) {
  62. AccessTokenDTO accessTokenDTO = response.getData();
  63. JedisUtil.set(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY, JacksonUtil.toJson(accessTokenDTO), (60 * 60 * 2) - (60 * 2));
  64. if (a) {
  65. JedisUtil.set(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY, Optional.ofNullable(accessTokenDTO.getRefreshToken()).orElse(""), (60 * 60 * 24 * 7));
  66. }
  67. } else if (Objects.nonNull(response) && !response.getSuccess() && Response.ErrorCodeEnum.INVALID_REFRESH.getErrorCode().equals(response.getErrorCode())) {
  68. log.info("海控会员系统RefreshToken已失效,重新获取AccessToken与RefreshToken!");
  69. JedisUtil.del(Constants.MEMBER_SYS_REFRESH_TOKEN_REDIS_KEY);
  70. refresh();
  71. } else {
  72. log.error("请求海控会员系统AccessToken返回响应为空!");
  73. }
  74. }
  75. public String getAccessToken() throws Exception {
  76. String accessTokenJson = JedisUtil.get(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  77. if (StringUtils.isEmpty(accessTokenJson)) {
  78. refresh();
  79. accessTokenJson = JedisUtil.get(Constants.MEMBER_SYS_ACCESS_TOKEN_REDIS_KEY);
  80. AccessTokenDTO accessTokenDTO = JacksonUtil.fromStringJson(accessTokenJson, AccessTokenDTO.class);
  81. if (Objects.isNull(accessTokenDTO)) {
  82. log.error("accessToken数据转为对象失败!");
  83. throw new Exception("accessToken数据转为对象失败!");
  84. }
  85. return accessTokenDTO.getAccessToken();
  86. } else {
  87. AccessTokenDTO accessTokenDTO = JacksonUtil.fromStringJson(accessTokenJson, AccessTokenDTO.class);
  88. if (Objects.isNull(accessTokenDTO)) {
  89. log.error("accessToken数据转为对象失败!");
  90. throw new Exception("accessToken数据转为对象失败!");
  91. }
  92. return accessTokenDTO.getAccessToken();
  93. }
  94. }
  95. }