From f4d06bc703a27865faaefed3c51d2ca21974edc5 Mon Sep 17 00:00:00 2001 From: "382696293@qq.com" <382696293@qq.com> Date: Tue, 19 Dec 2023 11:28:11 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=B7=E6=96=B0=E7=94=A8=E6=88=B7=E4=BF=A1?= =?UTF-8?q?=E6=81=AF=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../common/security/service/TokenService.java | 4 +-- .../controller/UserMemberController.java | 10 ++++++ .../service/IWxUserMemberService.java | 3 ++ .../service/impl/WxUserMemberServiceImpl.java | 35 +++++++++++++++++++ 4 files changed, 50 insertions(+), 2 deletions(-) diff --git a/flossom-common/flossom-common-security/src/main/java/com/flossom/common/security/service/TokenService.java b/flossom-common/flossom-common-security/src/main/java/com/flossom/common/security/service/TokenService.java index c0879b0..6be698b 100644 --- a/flossom-common/flossom-common-security/src/main/java/com/flossom/common/security/service/TokenService.java +++ b/flossom-common/flossom-common-security/src/main/java/com/flossom/common/security/service/TokenService.java @@ -56,8 +56,8 @@ public class TokenService loginUser.setUserid(userId); loginUser.setUsername(userName); if(loginUser.getWxUserMember() != null) { - loginUser.setWxUserid(loginUser.getWxUserid()); - loginUser.setWxUsername(loginUser.getWxUsername()); + loginUser.setWxUserid(loginUser.getWxUserMember().getId()); + loginUser.setWxUsername(loginUser.getWxUserMember().getNickname()); } loginUser.setIpaddr(IpUtils.getIpAddr()); refreshToken(loginUser); diff --git a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/controller/UserMemberController.java b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/controller/UserMemberController.java index 45713fc..a44c540 100644 --- a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/controller/UserMemberController.java +++ b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/controller/UserMemberController.java @@ -1,5 +1,6 @@ package com.flossom.miniProgram.controller; +import com.flossom.common.core.domain.R; import com.flossom.common.core.utils.StringUtils; import com.flossom.common.core.web.controller.BaseController; import com.flossom.common.core.web.domain.AjaxResult; @@ -63,4 +64,13 @@ public class UserMemberController extends BaseController { return AjaxResult.success(); } + /** + * 刷新用户信息 + * 1、重构用户缓存信息 + * 2、返回用户信息给前端缓存 + */ + @GetMapping("/refreshWxUserInfo") + public R refreshWxUserInfo() { + return R.ok(wxUserMemberService.refreshWxUserInfo()); + } } diff --git a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/IWxUserMemberService.java b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/IWxUserMemberService.java index b54128e..55c981a 100644 --- a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/IWxUserMemberService.java +++ b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/IWxUserMemberService.java @@ -11,4 +11,7 @@ public interface IWxUserMemberService { String upgradeMember(String code) throws Exception; void updateUser(UserMemberUpdateVo userMemberUpdateVo); + + LoginUserVo refreshWxUserInfo(); + } diff --git a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/impl/WxUserMemberServiceImpl.java b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/impl/WxUserMemberServiceImpl.java index ebfc039..0bc8c0c 100644 --- a/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/impl/WxUserMemberServiceImpl.java +++ b/flossom-modules/flossom-mini-program/src/main/java/com/flossom/miniProgram/service/impl/WxUserMemberServiceImpl.java @@ -16,6 +16,7 @@ import com.flossom.miniProgram.domain.vo.*; import com.flossom.miniProgram.service.IWxUserMemberService; import com.flossom.miniProgram.utils.MiniProgramUtils; import com.flossom.system.api.RemoteAuthService; +import com.flossom.system.api.model.LoginUser; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.BeanUtils; @@ -127,6 +128,40 @@ public class WxUserMemberServiceImpl implements IWxUserMemberService { BeanUtils.copyProperties(userMemberUpdateVo, wxUserMember); wxUserMember.setUpdateTime(DateUtils.getNowDate()); wxUserMemberMapper.updateWxUserMember(wxUserMember); + + // 重新构建用户信息缓存 + + } + + /** + * 重构用户缓存信息 + * + * @return + */ + @Override + public LoginUserVo refreshWxUserInfo() { + // 1、获取用户最新信息 + String openid = SecurityUtils.getLoginUser().getWxUserMember().getOpenid(); + WxUserMember wxUserMember = wxUserMemberMapper.selectWxUserMemberByOpenId(openid); + if (wxUserMember == null) { + logger.error("刷新用户信息失败"); + throw new ServiceException("刷新用户信息失败"); + } + + // 2、刷新redis缓存信息 + String userKey = SecurityUtils.getUserKey(); + LoginUser loginUser = redisService.getCacheObject(CacheConstants.LOGIN_TOKEN_KEY + userKey); + loginUser.setWxUserMember(wxUserMember); + loginUser.setWxUserid(wxUserMember.getId()); + loginUser.setUsername(wxUserMember.getNickname()); + loginUser.setExpireTime(loginUser.getLoginTime() + CacheConstants.EXPIRATION * 60 * 1000); + redisService.setCacheObject(userKey, loginUser, CacheConstants.EXPIRATION, TimeUnit.MINUTES); + + // 3、构建前端缓存对象 + LoginUserVo loginUserVo = new LoginUserVo(); + BeanUtils.copyProperties(wxUserMember, loginUserVo); + loginUserVo.setToken(loginUser.getToken()); + return loginUserVo; }