From ae9bfd2d66f68a553786ac78b12f4390e65e4e09 Mon Sep 17 00:00:00 2001 From: 44323 <443237572@qq.com> Date: 星期五, 24 十一月 2023 18:30:18 +0800 Subject: [PATCH] 后台bug修改 --- cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java | 195 ++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 176 insertions(+), 19 deletions(-) diff --git a/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java b/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java index 52181c6..6e8911b 100644 --- a/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java +++ b/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java @@ -4,10 +4,9 @@ import cn.hutool.http.HttpResponse; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; -import com.dsh.other.entity.Site; -import com.dsh.other.entity.SiteBooking; -import com.dsh.other.entity.SiteType; +import com.dsh.other.entity.*; import com.dsh.other.feignclient.account.CityManagerClient; import com.dsh.other.feignclient.activity.UserCouponClient; import com.dsh.other.feignclient.activity.model.QueryUserCouponByIdAndUserId; @@ -19,24 +18,23 @@ import com.dsh.other.model.dto.siteDto.TSiteDTO; import com.dsh.other.model.vo.siteVo.ExpireSiteSearchVO; import com.dsh.other.model.vo.siteVo.SiteSearchVO; -import com.dsh.other.service.ISiteBookingService; -import com.dsh.other.service.ISiteService; -import com.dsh.other.service.ISiteTypeService; -import com.dsh.other.util.PayMoneyUtil; -import com.dsh.other.util.ResultUtil; -import com.dsh.other.util.TokenUtil; +import com.dsh.other.service.*; +import com.dsh.other.util.*; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.web.bind.annotation.*; +import redis.clients.jedis.Jedis; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.PrintWriter; +import java.text.SimpleDateFormat; import java.util.*; +import java.util.stream.Collectors; /** * @author zhibing.pu @@ -113,12 +111,13 @@ * @return */ @RequestMapping("/base/site/addSite") - public Object addSite(@RequestBody Site site){ + public Integer addSite(@RequestBody Site site){ if(site.getId()!= null ){ - - return siteService.updateById(site); + siteService.updateById(site); + return site.getId(); }else { - return siteService.save(site); + boolean save = siteService.save(site); + return site.getId(); } } @@ -200,7 +199,8 @@ } } - + @Autowired + private RedisUtil redisUtil; @ResponseBody @PostMapping("/base/site/querySiteTimes") @@ -208,16 +208,34 @@ @ApiImplicitParams({ @ApiImplicitParam(value = "场地id", name = "id", dataType = "int", required = true), @ApiImplicitParam(value = "日期(2023-01-01)", name = "day", dataType = "string", required = true), + @ApiImplicitParam(value = "半场名称", name = "halfName", dataType = "string", required = false), + @ApiImplicitParam(value = "选择场地的名称", name = "siteName", dataType = "string", required = false) }) - public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day){ + public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day,String halfName,String siteName){ try { - List<QuerySiteTimes> list = siteService.querySiteTimes(id, day); + List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName); return ResultUtil.success(list); }catch (Exception e){ e.printStackTrace(); return ResultUtil.runErr(); } } + +// public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day, String halfName, String siteName) throws Exception { +// +// if (redisUtil.acquireLock(day,day)) { +// try { +// List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName); +// return ResultUtil.success(list); +// } finally { +// redisUtil.releaseLock(day); +// } +// } else { +// return ResultUtil.error("系统繁忙,请稍后再试!"); +// } +// +// } + /** @@ -257,6 +275,22 @@ } } +// public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day, String halfName, String siteName) throws Exception { +// +// if (redisUtil.acquireLock(day,day)) { +// try { +// List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName); +// return ResultUtil.success(list); +// } finally { +// redisUtil.releaseLock(day); +// } +// } else { +// return ResultUtil.error("系统繁忙,请稍后再试!"); +// } +// +// } + + /** * 购买课程微信支付回调 * @param request @@ -290,7 +324,7 @@ /** - * 购买课程支付宝回调 + * 预约场地支付宝回调 * @param request * @param response */ @@ -298,6 +332,7 @@ @PostMapping("/base/site/aliPaymentSiteCallback") public void aliPaymentSiteCallback(HttpServletRequest request, HttpServletResponse response){ try { + System.out.println("回调回调回调"); Map<String, String> map = payMoneyUtil.alipayCallback(request); if(null != map){ String code = map.get("out_trade_no"); @@ -320,6 +355,60 @@ } + /** + * 启动游戏支付宝回调 + * @param request + * @param response + */ + @ResponseBody + @PostMapping("/base/site/gameCallback") + public void gameCallback(HttpServletRequest request, HttpServletResponse response){ + try { + System.out.println("回调回调回调"); + Map<String, String> map = payMoneyUtil.alipayCallback(request); + if(null != map){ + + String code = map.get("passback_params"); +// String trade_no = map.get("trade_no"); +// SiteBooking siteBooking = siteBookingService.getOne(new QueryWrapper<SiteBooking>().eq("orderNo", code).eq("state", 1)); +// if(siteBooking.getStatus() == 0){ +// siteBooking.setPayTime(new Date()); +// siteBooking.setStatus(1); +// siteBooking.setPayOrderNo(trade_no); +// siteBookingService.updateById(siteBooking); +// } + + String[] s = code.split("_"); + Integer i = startGame(Integer.valueOf(s[0]), Integer.valueOf(s[1]), Integer.valueOf(s[2]), Integer.valueOf(s[3])); + System.err.println("===========游戏回调游戏回调========="+i); + PrintWriter out = response.getWriter(); + out.write("success"); + out.flush(); + out.close(); + } + }catch (Exception e){ + e.printStackTrace(); + } + } + + + private static Integer startGame(Integer uid,Integer gameId,Integer spaceId,Integer sutuId){ + HashMap<String, String> map = new HashMap<>(); + map.put("sign","0DB011836143EEE2C2E072967C9F4E4B"); + map.put("app_user_id",uid+""); + map.put("game_id",gameId+""); + map.put("space_id",spaceId+""); + map.put("sutu_id",sutuId+""); + + String s = HttpRequestUtil.postRequest("https://try.daowepark.com/v7/user_api/general/gameStart", map); + JSONObject jsonObject = JSONObject.parseObject(s); + Object code = jsonObject.get("code"); + if(String.valueOf(code)!=null && "200".equals(String.valueOf(code))){ + return 200; + }else { + return 500; + } + } @ResponseBody @@ -355,8 +444,43 @@ try { HashMap<String, Object> map = new HashMap<>(); SiteBooking byId = siteBookingService.getById(id); + Integer storeId = byId.getStoreId(); + Store byId1 = service.getById(storeId); + Site site = siteService.getById(byId.getSiteId()); + map.put("siteName",byId1.getName()); + SiteType siteType = siteTypeService.getById(site.getSiteTypeId()); + map.put("siteType",siteType.getName()); + map.put("shopName",byId1.getName()); + map.put("shopAddress",byId1.getAddress()); + + map.put("name",site.getName()); + + + List<Integer> ids = getIds(byId.getSiteId()); + byId.setStorePhone(byId1.getPhone()); + + //拼接开始结束时间 + Date startTime = byId.getStartTime(); + Date endTime = byId.getEndTime(); + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm"); + + String startTimeString = sdf.format(startTime); + String endTimeString = sdf.format(endTime); + + String result = startTimeString + "-" + endTimeString.substring(11); + byId.setTimes(result); + + + + + byId.setSid(Arrays.asList(storeId)); + List<Site> list = siteService.list(new LambdaQueryWrapper<Site>().eq(Site::getStoreId, storeId).eq(Site::getSign, 1)); + List<Integer> collect = list.stream().map(Site::getId).collect(Collectors.toList()); + byId.setRid(collect); map.put("data",byId); + + map.put("ids",ids); return ResultUtil.success(map); }catch (Exception e){ @@ -527,13 +651,46 @@ } + @Autowired + private StoreService service; + + @Autowired + private IOperatorUserService operatorUserService; + + + @ResponseBody + @PostMapping("/base/site/game") + public List<Map<String, Object>> game(@RequestBody Integer appUserId){ + return service.game(appUserId); + + } + + + @ResponseBody + @PostMapping("/base/site/counts") + public Integer counts(@RequestBody Integer stuId){ + return siteBookingService.count(new QueryWrapper<SiteBooking>().eq("appUserId",stuId)); + + } + + @ResponseBody + @PostMapping("/base/site/queryOperator") + public OperatorUser queryOperator(@RequestBody List<Integer> stores){ + + Store one = service.getOne(new QueryWrapper<Store>().in("id", stores)); + OperatorUser o = operatorUserService.getById(one.getOperatorId()); + + return o; + } + + @ResponseBody @PostMapping("/base/site/getNewAddSiteList") - public List<SiteVo> getAppUserSiteList(){ + public List<SiteVo> getAppUserSiteList(@RequestBody Integer storeId){ List<SiteVo> siteVos = new ArrayList<>(); - List<Site> list = siteService.list(new QueryWrapper<Site>() + List<Site> list = siteService.list(new QueryWrapper<Site>().eq("state",1).eq("storeId",storeId) .orderByDesc("insertTime")); if (list.size() > 0 ){ for (Site site : list) { -- Gitblit v1.7.1