From 6342a3c777f77a5c6cb41d0881c5bf82edebaa1f Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期一, 19 八月 2024 18:04:19 +0800 Subject: [PATCH] 账号注销 --- ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 56 insertions(+), 4 deletions(-) diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java index dd60931..88ebf05 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java @@ -16,14 +16,20 @@ import com.ruoyi.account.wx.model.WeixinProperties; import com.ruoyi.account.wx.tools.WxAppletTools; import com.ruoyi.account.util.GiveVipUtil; +import com.ruoyi.common.core.constant.Constants; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.enums.status.AppUserStatusEnum; +import com.ruoyi.common.core.utils.JwtUtils; +import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.core.utils.bean.BeanUtils; import com.ruoyi.common.core.web.domain.AjaxResult; import com.ruoyi.common.core.web.domain.BasePojo; import com.ruoyi.common.core.web.page.PageInfo; import com.ruoyi.common.redis.service.RedisService; import com.ruoyi.common.security.annotation.RequiresPermissions; +import com.ruoyi.common.security.auth.AuthUtil; import com.ruoyi.common.security.service.TokenService; +import com.ruoyi.common.security.utils.SecurityUtils; import com.ruoyi.order.api.feignClient.ChargingOrderClient; import com.ruoyi.order.api.feignClient.ExchangeOrderClient; import com.ruoyi.order.api.model.TChargingOrder; @@ -41,10 +47,12 @@ import lombok.extern.slf4j.Slf4j; import org.aspectj.weaver.loadtime.Aj; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import org.springframework.web.client.RestTemplate; import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; import java.time.Duration; import java.time.LocalDate; import java.time.LocalDateTime; @@ -88,10 +96,6 @@ private TokenService tokenService; @Autowired private RedisService redisService; - @Autowired - private WeixinProperties wxConfig; - @Autowired - private RestTemplate wxRestTemplate; @Resource private TAppUserSignService signService; @@ -155,6 +159,10 @@ otherClient.unitAddorUpadate(tCompany); return R.ok(); } + + + + @ApiOperation(value = "单位管理删除", tags = {"用户管理-单位管理"}) @DeleteMapping(value = "/unit/delete") public R add(@RequestParam String ids) { @@ -440,6 +448,39 @@ return R.ok(); } + @ApiOperation(value = "更换手机号", tags = {"小程序-用户管理-更换手机号"}) + @PostMapping(value = "/user/updatePhone") + public AjaxResult<String> updatePhone(@Validated @RequestBody UpdatePhoneDTO dto) { + String code = redisService.getCacheObject(dto.getPhone() + Constants.APPLET); + if(StringUtils.isEmpty(code)){ + return AjaxResult.error("验证码已过期,请重新获取验证码!"); + } + if(!code.equals(dto.getCode())){ + return AjaxResult.error("验证码错误!"); + } + // 获取当前用户信息 + Long userId = tokenService.getLoginUserApplet().getUserId(); + TAppUser appUser = appUserService.getById(userId); + appUser.setPhone(dto.getPhone()); + appUserService.updateById(appUser); + return AjaxResult.success(); + } + + @ApiOperation(value = "注销接口", tags = {"小程序-用户管理-注销账号"}) + @DeleteMapping("/logoff") + public AjaxResult<?> logoff(HttpServletRequest request) { + String token = SecurityUtils.getToken(request); + if (StringUtils.isNotEmpty(token)) + { + String userId = JwtUtils.getUserId(token); + // 账号注销 + appUserService.update(Wrappers.<TAppUser>lambdaUpdate().set(TAppUser::getStatus, AppUserStatusEnum.LOGOFF.getCode()).eq(TAppUser::getId, userId)); + // 删除用户缓存记录 + AuthUtil.logoutByToken(token); + } + return AjaxResult.success(); + } + /** * 根据用户id查询用户信息 * @param appUserIds 用户id @@ -475,6 +516,17 @@ return R.ok(); } + /** + * 通过手机号查询用户 + * @param phone + * @return + */ + @GetMapping("/user/selectByPhone") + public R<TAppUser> selectByPhone(@RequestParam("phone") String phone){ + return R.ok(appUserService.getOne(Wrappers.lambdaQuery(TAppUser.class) + .eq(TAppUser::getPhone,phone) + .last("LIMIT 1"))); + } // @ApiOperation(value = "签到", tags = {"小程序-个人中心-签到"}) // @PostMapping(value = "/user/sign") -- Gitblit v1.7.1