From 25743ef4cfb9da0be8d3e488c93f5429ffd02f8a Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期二, 21 五月 2024 14:21:25 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/DolphinEnglish

---
 ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TUserServiceImpl.java |   61 ++++++++++++++++++++++++++++++
 1 files changed, 61 insertions(+), 0 deletions(-)

diff --git a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TUserServiceImpl.java b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TUserServiceImpl.java
index 0fcce24..54ab466 100644
--- a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TUserServiceImpl.java
+++ b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TUserServiceImpl.java
@@ -1,14 +1,23 @@
 package com.ruoyi.study.service.impl;
 
+import cn.hutool.core.util.RandomUtil;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.constant.Constants;
+import com.ruoyi.common.core.constant.RedisConstants;
+import com.ruoyi.common.core.exception.GlobalException;
+import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.study.domain.TUser;
 import com.ruoyi.study.dto.AppUserQuery;
 import com.ruoyi.study.mapper.TUserMapper;
 import com.ruoyi.study.service.ITUserService;
 import com.ruoyi.study.vo.AppUserVO;
+import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Service;
 
+import javax.annotation.Resource;
+import java.util.Date;
 import java.util.List;
+import java.util.concurrent.TimeUnit;
 
 /**
  * <p>
@@ -21,8 +30,60 @@
 @Service
 public class TUserServiceImpl extends ServiceImpl<TUserMapper, TUser> implements ITUserService {
 
+    @Resource
+    private RedisTemplate<String, Object> redisTemplate;
+    @Resource
+    private TokenService tokenService;
+
     @Override
     public List<AppUserVO> listAll(AppUserQuery query) {
         return this.baseMapper.listAll(query);
     }
+
+    @Override
+    public Boolean phoneCode(String phone) {
+        // 生成随机 6位数字 验证码
+        String phoneCode = RandomUtil.randomNumbers(6);
+        // todo 手机验证码暂时 123456
+        phoneCode = "123456";
+        // 判断redis中是否存在手机验证码
+        Object phoneCodeRedis = redisTemplate.opsForValue().get(RedisConstants.PHONE_CODE + phone);
+        if (phoneCodeRedis == null) {
+            // 将手机验证码 key: reg:用户输入的手机号码  value: 随机验证码:时间戳
+            phoneCodeRedis = phoneCode;
+        } else {
+            // redis有验证码,获取redis中value的时间戳,判断是否过期
+            long oldTime = Long.parseLong(String.valueOf(phoneCodeRedis).split(":")[1]);
+            // 没有超过1分钟的重发时间
+            if (System.currentTimeMillis() - oldTime < (long) Constants.SIXTY * Constants.ONE_THOUSAND) {
+                throw new GlobalException("操作频繁,稍后重试!!!");
+            } else {
+                phoneCode = String.valueOf(phoneCodeRedis).split(":")[0];
+            }
+        }
+        /*
+         * 保存信息到redis
+         * key为 --> phone_code:手机号码 (phone_code表示该业务为 验证码登录)
+         * value为 --> 随机验证码:时间戳 (时间戳用于计算是否超过1分钟的重发时间)
+         */
+        redisTemplate.opsForValue().set(RedisConstants.PHONE_CODE + phone, phoneCode + ":" + System.currentTimeMillis(), 3, TimeUnit.MINUTES);
+        String sendMessage = "验证码发送成功,您的验证码为:" + phoneCode + ",该验证码三分钟内有效,请及时完成登陆";
+        // todo 发送此消息
+        System.out.println(sendMessage);
+        return true;
+    }
+
+    @Override
+    public Boolean isVip() {
+        TUser user = lambdaQuery().eq(TUser::getId, tokenService.getLoginUserStudy().getUserid())
+                .eq(TUser::getDisabled, 0).one();
+        // 是否为vip 逻辑
+        if (null == user) {
+            return false;
+        }
+        // vip过期时间,字段为空也表示 当前用户不是vip
+        Date vipEndTime = user.getVipEndTime();
+        return null != vipEndTime && System.currentTimeMillis() <= vipEndTime.getTime();
+    }
+
 }

--
Gitblit v1.7.1