From e26dff30daa39b59a0dd99ee175e065635a01cd9 Mon Sep 17 00:00:00 2001 From: lingling <kety1122@163.com> Date: 星期一, 24 三月 2025 15:41:21 +0800 Subject: [PATCH] 添加cache --- LifePayment/LifePayment.Application/User/AccountService.cs | 40 ++++++++++++++++++++++++++++++++-------- 1 files changed, 32 insertions(+), 8 deletions(-) diff --git a/LifePayment/LifePayment.Application/User/AccountService.cs b/LifePayment/LifePayment.Application/User/AccountService.cs index 2c46855..946210a 100644 --- a/LifePayment/LifePayment.Application/User/AccountService.cs +++ b/LifePayment/LifePayment.Application/User/AccountService.cs @@ -11,11 +11,13 @@ using System.Threading.Tasks; using Volo.Abp; using Volo.Abp.Application.Services; +using Volo.Abp.Caching; using Volo.Abp.Domain.Repositories; using Volo.Abp.Identity; using Volo.Abp.Identity.Application.Contracts.Account; using Volo.Abp.IdentityModel; using ZeroD.Util; +using ZeroD.Util.Fadd; using static LifePayment.Domain.Shared.LifePaymentConstant; @@ -30,6 +32,8 @@ private readonly IRepository<User, Guid> _userRepository; private readonly IRepository<UserChannle, Guid> _userChannleRep; private readonly IIdentityUserAppService _identityUserService; + private readonly IDistributedCache<string> _distributedCache; + public AccountService( IWxManager wxManager, @@ -38,7 +42,8 @@ IRepository<User, Guid> userRepository, IIdentityUserAppService identityUserService, IRepository<LifePayUser, Guid> lifePayUserRepository, - IRepository<UserChannle, Guid> userChannleRep) + IRepository<UserChannle, Guid> userChannleRep, + IDistributedCache<string> distributedCache) { _configuration = configuration; _wxManager = wxManager; @@ -47,19 +52,38 @@ _authenticator = authenticator; _userRepository = userRepository; _userChannleRep = userChannleRep; + _distributedCache = distributedCache; } #region 鏌ヨ public async Task<WxMiniAppIndentityInfo> GetLifePayWxIndentity(string code) { - var res = await _wxManager.GetWxOauth2AccessToken(code); - var result = new WxMiniAppIndentityInfo + var cacheData = await _distributedCache.GetAsync(code); + var result = new WxMiniAppIndentityInfo(); + if (cacheData != null) { - SessionKey = res.SessionKey, - OpenId = res.OpenId, - UnionId = res.UnionId - }; + result.OpenId = cacheData; + } + else + { + var res = await _wxManager.GetWxOauth2AccessToken(code); + result = new WxMiniAppIndentityInfo + { + SessionKey = res.SessionKey, + OpenId = res.OpenId, + UnionId = res.UnionId + }; + if (!string.IsNullOrEmpty(res.OpenId)) + { + await _distributedCache.SetAsync(code, res.OpenId, options: new Microsoft.Extensions.Caching.Distributed.DistributedCacheEntryOptions() + { + AbsoluteExpirationRelativeToNow = TimeSpan.FromMinutes(5) + }); + } + + } + return result; } @@ -129,7 +153,7 @@ var user = await _userRepository.Where(r => r.UserName == accessRequestDto.UserName && !r.IsDeleted).FirstOrDefaultAsync(); // 璁板綍鏃ュ織 - // await PublishUserOperateHistoryEvent(LogsSpecies.Login, LogsSpecies.Login, user.Id, user.Id, creatorName: user.Name); + // await PublishUserOperateHistoryEvent(LogsSpecies.Login, LogsSpecies.Login, user.Id, user.Id, creatorName: user.Name); return result; } -- Gitblit v1.9.1