From 75067731200e8bfbee363c283c10647805779e6e Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Mon, 12 Jun 2023 02:28:07 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java               |    2 
 src/main/java/cc/mrbird/febs/mall/controller/CommonController.java              |   59 ++++++++++---------
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |    2 
 src/main/java/cc/mrbird/febs/common/utils/Sms106Send.java                       |   66 ++++++++++++++++++++++
 src/main/resources/mapper/modules/MallOrderInfoMapper.xml                       |    1 
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java    |   14 ++--
 6 files changed, 106 insertions(+), 38 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/common/utils/Sms106Send.java b/src/main/java/cc/mrbird/febs/common/utils/Sms106Send.java
new file mode 100644
index 0000000..7d9d6a4
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/common/utils/Sms106Send.java
@@ -0,0 +1,66 @@
+package cc.mrbird.febs.common.utils;
+
+import cc.mrbird.febs.common.exception.FebsException;
+import cn.hutool.core.date.DatePattern;
+import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.StrUtil;
+import cn.hutool.core.util.XmlUtil;
+import cn.hutool.http.HttpUtil;
+import lombok.extern.slf4j.Slf4j;
+
+import java.util.Date;
+import java.util.HashMap;
+
+/**
+ * @author wzy
+ * @date 2020-07-14
+ **/
+@Slf4j
+public class Sms106Send {
+
+    private static final String URL = "http://www.qf106.com/sms.aspx";
+    private static final String ID = "16859";
+    private static final String ACCOUNT = "gcsm";
+    private static final String PASSWORD = "a123456";
+
+
+    /**
+     * @param phone 手机号
+     * @param code  验证码
+     * @param time  失效时间
+     * @return
+     */
+    public static boolean sendVerifyCode(String phone, String code, int time) {
+        String msg = "您的验证码是{},请在{}分钟内输入,请勿泄露给他人,如非本人操作,请及时修改密码。";
+        String content = StrUtil.format(msg, code, time);
+        return request(phone, content, "验证码");
+    }
+
+    private static boolean request(String phone, String content, String tagName) {
+        HashMap<String, Object> param = new HashMap<>();
+        param.put("userid", ID);
+        param.put("account", ACCOUNT);
+        param.put("password", PASSWORD);
+        param.put("mobile", phone);
+        param.put("content", content);
+        param.put("sendTime", DateUtil.format(new Date(), DatePattern.NORM_DATETIME_PATTERN));
+        param.put("action", "send");
+        param.put("checkcontent", 0);
+        param.put("taskName", tagName);
+        param.put("countnumber", 1);
+        param.put("mobilenumber", 1);
+        param.put("telephonenumber", 0);
+
+        String response = HttpUtil.post(URL, param);
+        log.info("短信发送:{}, {}", tagName, response);
+        if ("Success".equals(XmlUtil.xmlToMap(response).get("returnstatus"))) {
+            return true;
+        } else {
+            throw new FebsException((String) XmlUtil.xmlToMap(response).get("message"));
+        }
+    }
+
+    public static void main(String[] args) {
+        System.out.println(sendVerifyCode("15773002834", "123456", 2));
+    }
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java
index 15b8a83..8f86b54 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java
@@ -46,39 +46,40 @@
                                    @ApiParam(name = "type", value = "类型1-手机号", required = true) @RequestParam("type") String type) {
         log.info("#账号:{}, 类型:{}#", account, type);
 
-        Integer code = 123456;
-//        Integer code = (int) ((Math.random() * 9 + 1) * 100000);
+//        Integer code = 123456;
+        Integer code = (int) ((Math.random() * 9 + 1) * 100000);
         if (StrUtil.isNotBlank(redisUtils.getString(AppContants.VERIFY_CODE_PREFIX + account))) {
             throw new FebsException("验证码已发送");
         }
-        Map<String, Object> map = new HashMap<>();
-        boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
-        map.put("code", flag);
-        return new FebsResponse().success().message("验证码发送成功");
 
-//        // 发送手机验证码
-//        if (AppContants.ACCOUNT_TYPE_MOBILE.equals(type)) {
-//            boolean result = ZzSmsSend.sendVerifyCode(account, code.toString(), 2);
-//            if (result) {
-//                Map<String, Object> map = new HashMap<>();
-//                boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
-//                map.put("code", flag);
-//                return new FebsResponse().success().message("验证码发送成功");
-//            }
-//            // 发送邮件验证码
-//        } else if (AppContants.ACCOUNT_TYPE_EMAIL.equals(type)) {
-//            boolean flag = SubMailSend.sendMail(account, code.toString());
-//            if (flag) {
-//                redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
-//                return new FebsResponse().success().message("验证码发送成功");
-//            } else {
-//                return new FebsResponse().fail().message("验证码发送失败");
-//            }
-//        } else {
-//            log.info("未定义账号类型");
-//            throw new FebsException("未定义账号类型");
-//        }
-//        return new FebsResponse().fail().message("验证码发送失败");
+//        Map<String, Object> map = new HashMap<>();
+//        boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
+//        map.put("code", flag);
+//        return new FebsResponse().success().message("验证码发送成功");
+
+        // 发送手机验证码
+        if (AppContants.ACCOUNT_TYPE_MOBILE.equals(type)) {
+            boolean result = Sms106Send.sendVerifyCode(account, code.toString(), 2);
+            if (result) {
+                Map<String, Object> map = new HashMap<>();
+                boolean flag = redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
+                map.put("code", flag);
+                return new FebsResponse().success().message("验证码发送成功");
+            }
+            // 发送邮件验证码
+        } else if (AppContants.ACCOUNT_TYPE_EMAIL.equals(type)) {
+            boolean flag = SubMailSend.sendMail(account, code.toString());
+            if (flag) {
+                redisUtils.set(AppContants.VERIFY_CODE_PREFIX + account, code, 120);
+                return new FebsResponse().success().message("验证码发送成功");
+            } else {
+                return new FebsResponse().fail().message("验证码发送失败");
+            }
+        } else {
+            log.info("未定义账号类型");
+            throw new FebsException("未定义账号类型");
+        }
+        return new FebsResponse().fail().message("验证码发送失败");
     }
 
     /**
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
index 9b41781..9d5ed0a 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallOrderInfoMapper.java
@@ -66,5 +66,5 @@
 
     BigDecimal selectSumAmountByPayMethodAndSomeStatue(@Param("payMethod")String name, @Param("statues") List<Long> values);
 
-    List<MallOrderInfo> selectScoreOrderListInDate(@Param("startDate") Date startDate, @Param("endDate") Date endDate, @Param("goodsId") Long goodsId);
+    List<MallOrderInfo> selectScoreOrderListInDate(@Param("startDate") Date startDate, @Param("endDate") Date endDate, @Param("goodsId") Long goodsId,@Param("memberId") Long memberId);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index 1df1969..ff1222a 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -82,13 +82,13 @@
         }
 
         String account = registerDto.getAccount();
-//        if (!"admin".equals(registerDto.getRegistType())) {
-//            String code = registerDto.getCode();
-//            boolean flags = commonService.verifyCode(account, code);
-//            if (!flags) {
-//                throw new FebsException("验证码错误");
-//            }
-//        }
+        if (!"admin".equals(registerDto.getRegistType())) {
+            String code = registerDto.getCode();
+            boolean flags = commonService.verifyCode(account, code);
+            if (!flags) {
+                throw new FebsException("验证码错误");
+            }
+        }
 
         mallMember = new MallMember();
         mallMember.setPassword(SecureUtil.md5(registerDto.getPassword()));
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index e63d158..25797ed 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -149,7 +149,7 @@
 
                 if (mallGoods.getRulesTimes() != null && mallGoods.getRulesCnt() != null) {
                     DateTime startDate = DateUtil.offset(new Date(), DateField.DAY_OF_YEAR, -mallGoods.getRulesTimes());
-                    List<MallOrderInfo> orderInfos = this.baseMapper.selectScoreOrderListInDate(DateUtil.beginOfDay(startDate), DateUtil.endOfDay(new Date()), mallGoods.getId());
+                    List<MallOrderInfo> orderInfos = this.baseMapper.selectScoreOrderListInDate(DateUtil.beginOfDay(startDate), DateUtil.endOfDay(new Date()), mallGoods.getId(), member.getId());
                     if (CollUtil.isNotEmpty(orderInfos) && orderInfos.size() >= mallGoods.getRulesCnt()) {
                         throw new FebsException("超出领取最大限制");
                     }
diff --git a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
index 0056296..bb3975c 100644
--- a/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
+++ b/src/main/resources/mapper/modules/MallOrderInfoMapper.xml
@@ -327,5 +327,6 @@
         where orderInfo.order_time >= #{startDate}
             and orderInfo.order_time &lt;= #{endDate}
             and orderInfo.status in (2,3,4,5)
+            and orderInfo.member_id=#{memberId}
     </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.1