From cabda12d788eeb6e056113ac8352dfaf972490d9 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 20 十月 2025 17:10:44 +0800
Subject: [PATCH] bug修改,后台新增预约记录,玩湃惠民卡修改二维码参数规则,启动游戏取消校验是否订场校验

---
 cloud-server-activity/src/main/java/com/dsh/activity/controller/HuiminController.java |  208 +++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 156 insertions(+), 52 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/controller/HuiminController.java b/cloud-server-activity/src/main/java/com/dsh/activity/controller/HuiminController.java
index d10313d..c4ec3c3 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/controller/HuiminController.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/controller/HuiminController.java
@@ -28,6 +28,7 @@
 import com.dsh.activity.model.response.*;
 import com.dsh.activity.service.*;
 import com.dsh.activity.util.*;
+import com.dsh.activity.util.wx.WxV3PayConfig;
 import com.google.gson.Gson;
 import io.swagger.annotations.*;
 import io.swagger.models.auth.In;
@@ -52,7 +53,7 @@
  */
 @RestController
 @RequestMapping("/huimin")
-@Api(tags = "惠民卡新增")
+@Api(tags = "玩湃惠民卡新增")
 public class HuiminController {
 
     @Autowired
@@ -86,14 +87,15 @@
     private String smid = "2088330203191220";//平台支付宝商户号
 
 
+
     /**
-     * 查看惠民卡详情
+     * 查看玩湃惠民卡详情
      */
     @ResponseBody
     @PostMapping("/payHuiminCard")
-    @ApiOperation(value = "购买惠民卡")
+    @ApiOperation(value = "购买玩湃惠民卡")
     @ApiImplicitParams({
-            @ApiImplicitParam(value = "惠民卡id", name = "id", dataType = "int", required = true),
+            @ApiImplicitParam(value = "玩湃惠民卡id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(value = "支付方式1微信2支付宝", name = "payType", dataType = "int", required = true),
             @ApiImplicitParam(value = "绑定学员ids多,个逗号拼接", name = "studentIds", dataType = "String", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
@@ -106,12 +108,12 @@
             }
             THuiminCard huiminCard = huiminCardService.getById(id);
             if (huiminCard.getEndTime() != null && huiminCard.getEndTime().before(new Date())) {
-                return ResultUtil.error("该惠民卡已过期");
+                return ResultUtil.error("该玩湃惠民卡已过期");
             }
             if (huiminCard.getGrantCount() != null) {
                 if (huiminCard.getGrantCount() <= payHuiminService.lambdaQuery().eq(TPayHuimin::getCardId, huiminCard.getId())
                         .eq(TPayHuimin::getStatus, 2).count()) {
-                    return ResultUtil.error("该惠民卡已售完");
+                    return ResultUtil.error("该玩湃惠民卡已售完");
                 }
             }
             if (huiminCard.getLimitCount() != null) {
@@ -119,7 +121,7 @@
                         .eq(TPayHuimin::getStatus, 2)
                         .eq(TPayHuimin::getAppUserId, uid)
                         .count()) {
-                    return ResultUtil.error("该惠民卡购买次数已达上限");
+                    return ResultUtil.error("该玩湃惠民卡购买次数已达上限");
                 }
             }
             TPayHuimin tPayHuimin = new TPayHuimin();
@@ -157,13 +159,23 @@
             System.err.println("支付数据" + tPayHuimin);
             payHuiminService.save(tPayHuimin);
             BigDecimal bigDecimal = new BigDecimal(studentIds.split(",").length);
+            if (tPayHuimin.getSalesMoney().compareTo(BigDecimal.ZERO)==0){
+                // 零元购
+                tPayHuimin.setStatus(2);
+                tPayHuimin.setPaymentTime(new Date());
+                payHuiminService.updateById(tPayHuimin);
+                return ResultUtil.success();
+            }
             switch (payType) {
                 case 1:
-                    return payMoneyUtil.weixinpay("购买惠民卡" + "-" + 0, "", tPayHuimin.getCode(), tPayHuimin.getSalesMoney().toString(),
+                    // todo 惠民卡收入属于平台商户 定死
+                    return payMoneyUtil.weixinpay("购买玩湃惠民卡", "", tPayHuimin.getCode(), tPayHuimin.getSalesMoney().toString(),
                             "/base/huimin/callBack/weixinPayHuiminCallback", "APP", "");
+//                return payMoneyUtil.weixinpayV3("1720719391","购买玩湃惠民卡",tPayHuimin.getCode(),
+//                        "/base/huimin/callBack/weixinPayHuiminCallback1",tPayHuimin.getSalesMoney().toString());
                 case 2:
                     String string = tPayHuimin.getSalesMoney().toString();
-                    return payMoneyUtil.alipay(smid, "购买惠民卡", "购买惠民卡", "", tPayHuimin.getCode(), string,
+                    return payMoneyUtil.alipay(smid, "购买玩湃惠民卡", "购买玩湃惠民卡", "", tPayHuimin.getCode(), string,
                             "/base/huimin/callBack/aliPayHuiminCallback");
             }
 
@@ -176,13 +188,13 @@
 
 
     /**
-     * 查看惠民卡详情
+     * 查看玩湃惠民卡详情
      */
     @ResponseBody
     @PostMapping("/getHuiminCardDetail")
-    @ApiOperation(value = "查看惠民卡详情")
+    @ApiOperation(value = "查看玩湃惠民卡详情")
     @ApiImplicitParams({
-            @ApiImplicitParam(value = "惠民卡id", name = "id", dataType = "int", required = true),
+            @ApiImplicitParam(value = "玩湃惠民卡id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(value = "门店id", name = "storeId", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
     })
@@ -252,11 +264,11 @@
     }
 
     /**
-     * 惠民卡富文本内容-惠民卡列表
+     * 玩湃惠民卡富文本内容-玩湃惠民卡列表
      */
     @ResponseBody
     @PostMapping("/getHuiminAgreementAndList")
-    @ApiOperation(value = "惠民卡富文本内容-惠民卡列表")
+    @ApiOperation(value = "玩湃惠民卡富文本内容-玩湃惠民卡列表")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "页码,首页1", name = "pageSize", dataType = "int", required = true),
             @ApiImplicitParam(value = "页条数", name = "pageNo", dataType = "int", required = true),
@@ -269,13 +281,14 @@
             if (null == uid) {
                 return ResultUtil.tokenErr();
             }
+            SimpleDateFormat simpleDateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             HuiminAgreementVO huiminAgreementVO = new HuiminAgreementVO();
             List<THuiminCard> cardList = huiminCardService.getHuiminAgreementAndList(pageNo, pageSize, storeId);
             List<THuiminCard> list = huiminCardService.list();
 
             List<THuiminCard> cardListNolimit = huiminCardService.getHuiminAgreementAndListNolimit(storeId);
             if (cardListNolimit.isEmpty()) {
-                // 没有配置惠民卡 展示富文本内容
+                // 没有配置玩湃惠民卡 展示富文本内容
                 huiminAgreementVO.setShowType(1);
             } else {
                 huiminAgreementVO.setShowType(2);
@@ -376,27 +389,52 @@
                                 Date start = DateUtil.parse(s1, "yyyy-MM-dd HH:mm:ss");
                                 Date end = DateUtil.parse(e1, "yyyy-MM-dd HH:mm:ss");
                                 if (new Date().after(start) && new Date().before(end)) {
-//                                    jsonObject2.put("start_time", start.getTime() / 1000);
+//                                    
                                     Date date1 = new Date();
-                                    jsonObject2.put("start_time", date1.getTime() / 1000);
+                                    jsonObject2.put("start_time", simpleDateFormat1.format( date1));
                                     date1.setTime(date1.getTime() + 30 * 1000);
                                     if (start.before(end)) {
-                                        jsonObject2.put("end_time", date1.getTime() / 1000);
+                                        jsonObject2.put("end_time", simpleDateFormat1.format( date1));
                                         jsonArray.add(jsonObject2);
                                     }
                                 }
+                            }else{
+                                // 返回过期的二维码 保证开门失败即可
+                                JSONObject jsonObject3 = new JSONObject();
+                                Date date1 = new Date();
+                                date1.setTime(date1.getTime() - 300 * 1000);
+                                jsonObject3.put("end_time", simpleDateFormat1.format( date1));
+                                jsonObject3.put("start_time", simpleDateFormat1.format( date1));
+
+                                jsonArray.add(jsonObject3);
                             }
                         }
                     }
+                }
+                else{
+                    // 返回过期的二维码 保证开门失败即可
+                    JSONObject jsonObject3 = new JSONObject();
+                    Date date1 = new Date();
+                    date1.setTime(date1.getTime() - 300 * 1000);
+                    jsonObject3.put("end_time", simpleDateFormat1.format( date1));
+                    jsonObject3.put("start_time", simpleDateFormat1.format( date1));
+
+                    jsonArray.add(jsonObject3);
                 }
                 if (!jsonArray.isEmpty()) {
                     huiminCardVO1.setEndTime(simpleDateFormat.format(payHuimin.getEndTime()));
                     TStudent tStudent = tStudents.stream().filter(e -> e.getId().equals(Integer.valueOf(payHuimin.getStudentId().split(",")[0]))).findFirst().orElse(null);
                     if (tStudent!=null){
                         huiminCardVO1.setStudentName(tStudent.getName());
+                        String temp = "{\"id\":"+payHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tStudent.getId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
+                        huiminCardVO1.setQrCode(temp);
+
+                    }else{
+                        huiminCardVO1.setStudentName("");
+
+                        String temp = "{\"id\":"+payHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tStudent.getId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
+                        huiminCardVO1.setQrCode(temp);
                     }
-                    String temp = "{\"id\":"+payHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + payHuimin.getStudentId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
-                    huiminCardVO1.setQrCode(temp);
                     huiminCardVOS.add(huiminCardVO1);
                     integers.add(payHuimin.getCardId());
 
@@ -450,13 +488,13 @@
     }
 
     /**
-     * 惠民卡列表-根据惠民卡获取已购买绑定惠民卡的学员列表
+     * 玩湃惠民卡列表-根据玩湃惠民卡获取已购买绑定玩湃惠民卡的学员列表
      */
     @ResponseBody
     @PostMapping("/getStudentListByCarId")
-    @ApiOperation(value = "惠民卡列表-根据惠民卡获取已购买绑定惠民卡的学员列表")
+    @ApiOperation(value = "玩湃惠民卡列表-根据玩湃惠民卡获取已购买绑定玩湃惠民卡的学员列表")
     @ApiImplicitParams({
-            @ApiImplicitParam(value = "惠民卡id", name = "id", dataType = "int", required = true),
+            @ApiImplicitParam(value = "玩湃惠民卡id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
     })
     public ResultUtil<List<TStudent>> getStudentListByCarId(Integer id) {
@@ -465,6 +503,7 @@
             if (null == uid) {
                 return ResultUtil.tokenErr();
             }
+            SimpleDateFormat simpleDateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             List<TPayHuimin> payHuimins = payHuiminService.list(new LambdaQueryWrapper<TPayHuimin>()
                     .eq(TPayHuimin::getAppUserId, uid)
                     .eq(TPayHuimin::getCardId, id)
@@ -520,18 +559,36 @@
                                     Date start = DateUtil.parse(s1, "yyyy-MM-dd HH:mm:ss");
                                     Date end = DateUtil.parse(e1, "yyyy-MM-dd HH:mm:ss");
                                     if (new Date().after(start) && new Date().before(end)) {
-//                                    jsonObject2.put("start_time", start.getTime() / 1000);
+//                                    
                                         Date date1 = new Date();
-                                        jsonObject2.put("start_time", date1.getTime() / 1000);
+                                        jsonObject2.put("start_time", simpleDateFormat1.format( date1));
                                         date1.setTime(date1.getTime() + 30 * 1000);
                                         if (start.before(end)) {
-                                            jsonObject2.put("end_time", date1.getTime() / 1000);
+                                            jsonObject2.put("end_time", simpleDateFormat1.format( date1));
                                             jsonArray.add(jsonObject2);
                                         }
                                     }
+                                }else{
+                                    // 返回过期的二维码 保证开门失败即可
+                                    JSONObject jsonObject3 = new JSONObject();
+                                    Date date1 = new Date();
+                                    date1.setTime(date1.getTime() - 300 * 1000);
+                                    jsonObject3.put("end_time", simpleDateFormat1.format( date1));
+                                    jsonObject3.put("start_time", simpleDateFormat1.format( date1));
+
+                                    jsonArray.add(jsonObject3);
                                 }
                             }
                         }
+                    }else{
+                        // 返回过期的二维码 保证开门失败即可
+                        JSONObject jsonObject = new JSONObject();
+                        Date date1 = new Date();
+                        date1.setTime(date1.getTime() - 300 * 1000);
+                        jsonObject.put("end_time", simpleDateFormat1.format( date1));
+                        jsonObject.put("start_time", simpleDateFormat1.format( date1));
+
+                        jsonArray.add(jsonObject);
                     }
                     if (!jsonArray.isEmpty()) {
                         // 将学员加入
@@ -551,13 +608,13 @@
     }
 
     /**
-     * 惠民卡列表-选择学员后返回对应的二维码生成规则和有效期结束时间
+     * 玩湃惠民卡列表-选择学员后返回对应的二维码生成规则和有效期结束时间
      */
     @ResponseBody
     @PostMapping("/getQrCodeByStudentId")
-    @ApiOperation(value = "惠民卡列表-选择学员后返回对应的二维码生成规则和有效期结束时间")
+    @ApiOperation(value = "玩湃惠民卡列表-选择学员后返回对应的二维码生成规则和有效期结束时间")
     @ApiImplicitParams({
-            @ApiImplicitParam(value = "惠民卡id", name = "cardId", dataType = "int", required = true),
+            @ApiImplicitParam(value = "玩湃惠民卡id", name = "cardId", dataType = "int", required = true),
             @ApiImplicitParam(value = "学员id", name = "studentId", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
     })
@@ -567,6 +624,7 @@
             if (null == uid) {
                 return ResultUtil.tokenErr();
             }
+            SimpleDateFormat simpleDateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             List<TStudent> tStudents = studentClient.queryStudentList(uid);
 
             List<TPayHuimin> payHuimins = payHuiminService.list(new LambdaQueryWrapper<TPayHuimin>()
@@ -628,29 +686,51 @@
                                 // 转化为Date类型
                                 Date start = DateUtil.parse(s1, "yyyy-MM-dd HH:mm:ss");
                                 Date end = DateUtil.parse(e1, "yyyy-MM-dd HH:mm:ss");
-                                jsonObject2.put("start_time", start.getTime() / 1000);
+                                
                                 start.setTime(start.getTime() + 30 * 1000);
                                 if (new Date().after(start) && new Date().before(end)) {
-//                                    jsonObject2.put("start_time", start.getTime() / 1000);
+//                                    
                                     Date date1 = new Date();
-                                    jsonObject2.put("start_time", date1.getTime() / 1000);
+                                    jsonObject2.put("start_time", simpleDateFormat1.format( date1));
                                     date1.setTime(date1.getTime() + 30 * 1000);
                                     if (start.before(end)) {
-                                        jsonObject2.put("end_time", date1.getTime() / 1000);
+                                        jsonObject2.put("end_time", simpleDateFormat1.format( date1));
                                         jsonArray.add(jsonObject2);
                                     }
                                 }
+                            }else{
+                                // 返回过期的二维码 保证开门失败即可
+                                JSONObject jsonObject3 = new JSONObject();
+                                Date date1 = new Date();
+                                date1.setTime(date1.getTime() - 300 * 1000);
+                                jsonObject3.put("end_time", simpleDateFormat1.format( date1));
+                                jsonObject3.put("start_time", simpleDateFormat1.format( date1));
+
+                                jsonArray.add(jsonObject3);
                             }
                         }
                     }
-                }
+                }else{
+                    // 返回过期的二维码 保证开门失败即可
+                    JSONObject jsonObject = new JSONObject();
+                    Date date1 = new Date();
+                    date1.setTime(date1.getTime() - 300 * 1000);
+                    jsonObject.put("end_time", simpleDateFormat1.format( date1));
+                    jsonObject.put("start_time", simpleDateFormat1.format( date1));
 
-                String temp = "{\"id\":"+tPayHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tPayHuimin.getStudentId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
-                huiminCardStudentVO.setQrCode(temp);
+                    jsonArray.add(jsonObject);
+                }
                 TStudent tStudent = tStudents.stream().filter(e -> e.getId().equals(studentId)).findFirst().orElse(null);
                 if (tStudent!=null){
                     huiminCardStudentVO.setStudentName(tStudent.getName());
+                    String temp = "{\"id\":"+tPayHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tStudent.getId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
+                    huiminCardStudentVO.setQrCode(temp);
+                }else{
+                    huiminCardStudentVO.setStudentName("");
+                    String temp = "{\"id\":"+tPayHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tStudent.getId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
+                    huiminCardStudentVO.setQrCode(temp);
                 }
+
             }
 
 
@@ -661,11 +741,11 @@
     }
 
     /**
-     * 惠民卡富文本内容-惠民卡列表
+     * 玩湃惠民卡富文本内容-玩湃惠民卡列表
      */
     @ResponseBody
     @PostMapping("/myHuiminCardList")
-    @ApiOperation(value = "个人中心-我的惠民卡")
+    @ApiOperation(value = "个人中心-我的玩湃惠民卡")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "页码,首页1", name = "pageSize", dataType = "int", required = true),
             @ApiImplicitParam(value = "页条数", name = "pageNo", dataType = "int", required = true),
@@ -725,11 +805,11 @@
     }
 
     /**
-     * 个人中心-我的惠民卡-退款
+     * 个人中心-我的玩湃惠民卡-退款
      */
     @ResponseBody
     @PostMapping("/refund")
-    @ApiOperation(value = "个人中心-我的惠民卡-退款")
+    @ApiOperation(value = "个人中心-我的玩湃惠民卡-退款")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "支付记录id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
@@ -741,6 +821,12 @@
                 return ResultUtil.tokenErr();
             }
             TPayHuimin tPayHuimin = payHuiminService.getById(id);
+            if (tPayHuimin.getPaymentType()==3){
+                // 后台录入直接退款
+                tPayHuimin.setStatus(3);
+                payHuiminService.updateById(tPayHuimin);
+                return ResultUtil.success();
+            }
             if (tPayHuimin == null) {
                 return ResultUtil.error("订单不存在");
             }
@@ -750,9 +836,8 @@
 
             if (tPayHuimin.getEndTime().before(new Date())) {
                 // 已过期
-                return ResultUtil.error("惠民卡已过期,不可退款");
+                return ResultUtil.error("玩湃惠民卡已过期,不可退款");
             }
-            tPayHuimin.setStatus(4);
             payHuiminService.updateById(tPayHuimin);
             int count = huiminRecordService.list(new LambdaQueryWrapper<THuiminRecord>()
                     .eq(THuiminRecord::getPayId, tPayHuimin.getId())).size();
@@ -760,9 +845,9 @@
             // 购卡7日内没有使用记录可退款。超过7日不管有没有使用记录都不能退款
             if (new Date().after(DateUtil.addDay(tPayHuimin.getPaymentTime(), 7))) {
                 // 超过七天不可退款
-                return ResultUtil.error("惠民卡购买超过七天,不可退款");
+                return ResultUtil.error("玩湃惠民卡购买超过七天,不可退款");
             } else if (count > 0) {
-                return ResultUtil.error("惠民卡已使用,不可退款");
+                return ResultUtil.error("玩湃惠民卡已使用,不可退款");
             }
             if (tPayHuimin.getPaymentType() == 1) {
                 Map<String, String> map = payMoneyUtil.wxRefund(tPayHuimin.getOrderNumber(), tPayHuimin.getCode(),
@@ -796,11 +881,11 @@
 
 
     /**
-     * 个人中心-我的惠民卡-查看详情
+     * 个人中心-我的玩湃惠民卡-查看详情
      */
     @ResponseBody
     @PostMapping("/myHuiminCardDetail")
-    @ApiOperation(value = "个人中心-我的惠民卡-查看详情")
+    @ApiOperation(value = "个人中心-我的玩湃惠民卡-查看详情")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "支付记录id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
@@ -813,8 +898,9 @@
             }
             TPayHuimin tPayHuimin = payHuiminService.getById(id);
             if (tPayHuimin == null) {
-                return ResultUtil.error("惠民卡不存在");
+                return ResultUtil.error("玩湃惠民卡不存在");
             }
+            SimpleDateFormat simpleDateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             THuiminCard byId = huiminCardService.getById(tPayHuimin.getCardId());
             MyHuiminCardDetailVO myHuiminCardDetailVO = new MyHuiminCardDetailVO();
             List<TStudent> studentByIds1 = studentClient.getStudentByIds(tPayHuimin.getStudentId());
@@ -865,24 +951,42 @@
                             // 转化为Date类型
                             Date start = DateUtil.parse(s1, "yyyy-MM-dd HH:mm:ss");
                             Date end = DateUtil.parse(e1, "yyyy-MM-dd HH:mm:ss");
-                            jsonObject2.put("start_time", start.getTime() / 1000);
+                            
                             start.setTime(start.getTime() + 30 * 1000);
                             if (new Date().after(start) && new Date().before(end)) {
-//                                    jsonObject2.put("start_time", start.getTime() / 1000);
+//                                    
                                 Date date1 = new Date();
-                                jsonObject2.put("start_time", date1.getTime() / 1000);
+                                jsonObject2.put("start_time", simpleDateFormat1.format( date1));
                                 date1.setTime(date1.getTime() + 30 * 1000);
                                 if (start.before(end)) {
-                                    jsonObject2.put("end_time", date1.getTime() / 1000);
+                                    jsonObject2.put("end_time", simpleDateFormat1.format( date1));
                                     jsonArray.add(jsonObject2);
                                 }
                             }
+                        }else{
+                            // 返回过期的二维码 保证开门失败即可
+                            JSONObject jsonObject3 = new JSONObject();
+                            Date date1 = new Date();
+                            date1.setTime(date1.getTime() - 300 * 1000);
+                            jsonObject3.put("end_time", simpleDateFormat1.format( date1));
+                            jsonObject3.put("start_time", simpleDateFormat1.format( date1));
+
+                            jsonArray.add(jsonObject3);
                         }
                     }
                 }
+            }else{
+                // 返回过期的二维码 保证开门失败即可
+                JSONObject jsonObject = new JSONObject();
+                Date date1 = new Date();
+                date1.setTime(date1.getTime() - 300 * 1000);
+                jsonObject.put("end_time", simpleDateFormat1.format( date1));
+                jsonObject.put("start_time", simpleDateFormat1.format( date1));
+
+                jsonArray.add(jsonObject);
             }
 
-            String temp = "{\"id\":"+tPayHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tPayHuimin.getStudentId() + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
+            String temp = "{\"id\":"+tPayHuimin.getId()  + ","+"\"sid\":" + sid.toJSONString() + "," + "\"rid\":" + rid + "," + "\"uid\":\"" + tPayHuimin.getStudentId().split(",")[0] + "\"," + "\"time\":" + jsonArray.toJSONString() + ",\"type\":" + 2 + "}";
             myHuiminCardDetailVO.setQrCode(temp);
             myHuiminCardDetailVO.setCardId(tPayHuimin.getCardId());
             myHuiminCardDetailVO.setHuiminCard(byId);

--
Gitblit v1.7.1