|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.date.DateUtil; | 
|---|
|  |  |  | import cn.hutool.poi.excel.ExcelUtil; | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.dsh.competition.entity.UserCompetition; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.AppUserClient; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.StudentClient; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.StudentHonorClient; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.model.AppUser; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.model.StudentHonor; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.account.model.TStudent; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.course.CoursePackagePaymentClient; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.course.model.PaymentDeductionClassHour; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.model.*; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.other.StoreClient; | 
|---|
|  |  |  | import com.dsh.competition.feignclient.other.model.Store; | 
|---|
|  |  |  | import com.dsh.competition.model.*; | 
|---|
|  |  |  | import com.dsh.competition.service.CompetitionService; | 
|---|
|  |  |  | import com.dsh.competition.service.IParticipantService; | 
|---|
|  |  |  | import com.dsh.competition.service.IPaymentCompetitionService; | 
|---|
|  |  |  | import com.dsh.competition.service.UserCompetitionService; | 
|---|
|  |  |  | import com.dsh.competition.util.PayMoneyUtil; | 
|---|
|  |  |  | import com.dsh.competition.util.ResultUtil; | 
|---|
|  |  |  | import com.dsh.competition.util.TokenUtil; | 
|---|
|  |  |  | import com.dsh.competition.util.ToolUtil; | 
|---|
|  |  |  | import com.dsh.competition.util.*; | 
|---|
|  |  |  | import com.dsh.competition.util.wx.WxV3PayConfig; | 
|---|
|  |  |  | import com.wechat.pay.contrib.apache.httpclient.util.AesUtil; | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParam; | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParams; | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import lombok.Synchronized; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletRequest; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.io.BufferedReader; | 
|---|
|  |  |  | import java.io.OutputStream; | 
|---|
|  |  |  | import java.io.PrintWriter; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.nio.charset.StandardCharsets; | 
|---|
|  |  |  | import java.text.DateFormat; | 
|---|
|  |  |  | import java.text.SimpleDateFormat; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private AppUserClient appUserClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private StudentHonorClient studentHonorClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据门店ids 获取对应的赛事 根据赛事支付记录获取用户ids | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | 
|---|
|  |  |  | // 获取到赛事id集合 去重 | 
|---|
|  |  |  | List<Integer> collect = comIds.stream().distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | // 根据赛事id 查询赛事支付记录 获取用户ids | 
|---|
|  |  |  | if (collect.size() == 0) { | 
|---|
|  |  |  | if (collect.isEmpty()) { | 
|---|
|  |  |  | return new ArrayList<>(); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | List<Integer> userIds = paymentCompetitionService.list(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .in("competitionId", collect)).stream() | 
|---|
|  |  |  | .in("competitionId", collect) | 
|---|
|  |  |  | .eq("payStatus",2)).stream() | 
|---|
|  |  |  | .map(PaymentCompetition::getAppUserId).collect(Collectors.toList()); | 
|---|
|  |  |  | return userIds; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Integer> operatorId = cttService.list(new QueryWrapper<Competition>() | 
|---|
|  |  |  | .eq("operatorId", operatorId1)).stream().map(Competition::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | query.setUserIds(operatorId); | 
|---|
|  |  |  | } else if (query.getStoreId() != null) { | 
|---|
|  |  |  | List<Competition> list = cttService.list(new QueryWrapper<Competition>()); | 
|---|
|  |  |  | List<Integer> integers = new ArrayList<>(); | 
|---|
|  |  |  | for (Competition competition : list) { | 
|---|
|  |  |  | for (String s : competition.getStoreId().split(",")) { | 
|---|
|  |  |  | if (s.equals(""+query.getStoreId())){ | 
|---|
|  |  |  | integers.add(competition.getId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (integers.isEmpty()){ | 
|---|
|  |  |  | integers.add(-1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | query.setUserIds(integers); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<PaymentCompetition> paymentCompetitions = paymentCompetitionService.listAll(query); | 
|---|
|  |  |  | List<PaymentCompetition> result = new ArrayList<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public synchronized ResultUtil paymentCompetition(PaymentCompetitionVo paymentCompetitionVo) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Competition byId = competitionService.getById(paymentCompetitionVo.getId()); | 
|---|
|  |  |  | Date date = byId.getEndTime(); | 
|---|
|  |  |  | // Assuming you have a Date object | 
|---|
|  |  |  | // Check if the date is past the current time | 
|---|
|  |  |  | boolean isPast = date.after(new Date()); | 
|---|
|  |  |  | if (!isPast) { | 
|---|
|  |  |  | return new ResultUtil(0, "已超过截至报名时间"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 报名赛事微信支付回调 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param request | 
|---|
|  |  |  | * @param response | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | @PostMapping("/base/competition/weChatPaymentCompetitionCallback1") | 
|---|
|  |  |  | public void weChatPaymentCompetitionCallback1(HttpServletRequest request, HttpServletResponse response) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | System.err.println("微信回调"); | 
|---|
|  |  |  | System.err.println("请求" + request); | 
|---|
|  |  |  | BufferedReader reader = request.getReader(); | 
|---|
|  |  |  | String string1 = reader.toString(); | 
|---|
|  |  |  | System.err.println("请求reader" + string1); | 
|---|
|  |  |  | StringBuilder requestBody = new StringBuilder(); | 
|---|
|  |  |  | String line; | 
|---|
|  |  |  | while ((line = reader.readLine()) != null) { | 
|---|
|  |  |  | requestBody.append(line); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | System.err.println("全部请求体" + requestBody); | 
|---|
|  |  |  | JSONObject jsonObject = JSONObject.parseObject(requestBody.toString()); | 
|---|
|  |  |  | JSONObject resource = jsonObject.getJSONObject("resource"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | AesUtil aesUtil = new AesUtil(WxV3PayConfig.apiV3Key.getBytes(StandardCharsets.UTF_8)); | 
|---|
|  |  |  | String decryptedData = aesUtil.decryptToString(resource.getString("associated_data").getBytes(StandardCharsets.UTF_8), resource.getString("nonce").getBytes(StandardCharsets.UTF_8), | 
|---|
|  |  |  | resource.getString("ciphertext")); | 
|---|
|  |  |  | System.err.println("微信解密的字符串信息" + decryptedData); | 
|---|
|  |  |  | JSONObject jsonInfo = (JSONObject) JSONObject.parse(decryptedData); | 
|---|
|  |  |  | String code = jsonInfo.getString("out_trade_no"); | 
|---|
|  |  |  | String transaction_id = jsonInfo.getString("transaction_id"); | 
|---|
|  |  |  | String trade_state = jsonInfo.getString("trade_state"); | 
|---|
|  |  |  | if (trade_state.equals("SUCCESS")) { | 
|---|
|  |  |  | PaymentCompetition paymentCompetition = paymentCompetitionService.getOne(new QueryWrapper<PaymentCompetition>().eq("code", code).eq("payType", 1)); | 
|---|
|  |  |  | if (paymentCompetition.getPayStatus() == 1) { | 
|---|
|  |  |  | paymentCompetition.setAppUserId(null); | 
|---|
|  |  |  | paymentCompetition.setPayStatus(2); | 
|---|
|  |  |  | paymentCompetition.setPayTime(new Date()); | 
|---|
|  |  |  | paymentCompetition.setPayOrderNo(transaction_id); | 
|---|
|  |  |  | paymentCompetitionService.updateById(paymentCompetition); | 
|---|
|  |  |  | Competition competition = cttService.getById(paymentCompetition.getCompetitionId()); | 
|---|
|  |  |  | competition.setApplicantsNumber(competition.getApplicantsNumber() + 1); | 
|---|
|  |  |  | cttService.updateById(competition); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PrintWriter out = response.getWriter(); | 
|---|
|  |  |  | out.write("SUCCESS"); | 
|---|
|  |  |  | out.flush(); | 
|---|
|  |  |  | out.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 报名赛事微信支付回调 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | 
|---|
|  |  |  | String code = map.get("out_refund_no"); | 
|---|
|  |  |  | String refund_id = map.get("refund_id"); | 
|---|
|  |  |  | String result = map.get("result"); | 
|---|
|  |  |  | PaymentCompetition paymentCompetition = paymentCompetitionService.getOne(new QueryWrapper<PaymentCompetition>().eq("code", code).eq("payType", 1)); | 
|---|
|  |  |  | if (paymentCompetition.getPayStatus() == 1) { | 
|---|
|  |  |  | PaymentCompetition paymentCompetition = paymentCompetitionService.getOne(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("code", code).eq("payType", 1)); | 
|---|
|  |  |  | if (paymentCompetition.getPayStatus() == 2) { | 
|---|
|  |  |  | paymentCompetition.setPayStatus(3); | 
|---|
|  |  |  | paymentCompetition.setRefundTime(new Date()); | 
|---|
|  |  |  | paymentCompetition.setRefundOrderNo(refund_id); | 
|---|
|  |  |  | 
|---|
|  |  |  | Competition competition = cttService.getById(paymentCompetition.getCompetitionId()); | 
|---|
|  |  |  | competition.setApplicantsNumber(competition.getApplicantsNumber() - 1); | 
|---|
|  |  |  | cttService.updateById(competition); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PrintWriter out = response.getWriter(); | 
|---|
|  |  |  | out.write(result); | 
|---|
|  |  |  | out.flush(); | 
|---|
|  |  |  | out.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 取消已报名赛事后微信回退金额回调微信V3服务商版本 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param request | 
|---|
|  |  |  | * @param response | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | @PostMapping("/base/competition/weChatCancelPaymentCompetitionCallback1") | 
|---|
|  |  |  | public void weChatCancelPaymentCompetitionCallback1(HttpServletRequest request, HttpServletResponse response) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | System.err.println("微信回调"); | 
|---|
|  |  |  | System.err.println("请求" + request); | 
|---|
|  |  |  | BufferedReader reader = request.getReader(); | 
|---|
|  |  |  | String string1 = reader.toString(); | 
|---|
|  |  |  | System.err.println("请求reader" + string1); | 
|---|
|  |  |  | StringBuilder requestBody = new StringBuilder(); | 
|---|
|  |  |  | String line; | 
|---|
|  |  |  | while ((line = reader.readLine()) != null) { | 
|---|
|  |  |  | requestBody.append(line); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | System.err.println("全部请求体" + requestBody); | 
|---|
|  |  |  | JSONObject jsonObject = JSONObject.parseObject(requestBody.toString()); | 
|---|
|  |  |  | JSONObject resource = jsonObject.getJSONObject("resource"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | AesUtil aesUtil = new AesUtil(WxV3PayConfig.apiV3Key.getBytes(StandardCharsets.UTF_8)); | 
|---|
|  |  |  | String decryptedData = aesUtil.decryptToString(resource.getString("associated_data").getBytes(StandardCharsets.UTF_8), resource.getString("nonce").getBytes(StandardCharsets.UTF_8), | 
|---|
|  |  |  | resource.getString("ciphertext")); | 
|---|
|  |  |  | System.err.println("微信解密的字符串信息" + decryptedData); | 
|---|
|  |  |  | JSONObject jsonInfo = (JSONObject) JSONObject.parse(decryptedData); | 
|---|
|  |  |  | String code = jsonInfo.getString("out_trade_no"); | 
|---|
|  |  |  | String transaction_id = jsonInfo.getString("transaction_id"); | 
|---|
|  |  |  | String refund_status = jsonInfo.getString("refund_status"); | 
|---|
|  |  |  | String out_refund_no = jsonInfo.getString("out_refund_no"); | 
|---|
|  |  |  | if (refund_status.equals("SUCCESS")) { | 
|---|
|  |  |  | PaymentCompetition paymentCompetition = paymentCompetitionService.getOne(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("code", code).eq("payType", 1)); | 
|---|
|  |  |  | if (paymentCompetition.getPayStatus() == 2) { | 
|---|
|  |  |  | paymentCompetition.setPayStatus(3); | 
|---|
|  |  |  | paymentCompetition.setRefundTime(new Date()); | 
|---|
|  |  |  | paymentCompetition.setRefundOrderNo(out_refund_no); | 
|---|
|  |  |  | paymentCompetition.setAppUserId(null); | 
|---|
|  |  |  | paymentCompetitionService.updateById(paymentCompetition); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Competition competition = cttService.getById(paymentCompetition.getCompetitionId()); | 
|---|
|  |  |  | competition.setApplicantsNumber(competition.getApplicantsNumber() - 1); | 
|---|
|  |  |  | cttService.updateById(competition); | 
|---|
|  |  |  | storeClient.addBackRecord(paymentCompetition.getAmount() + "_" + paymentCompetition.getAppUserId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | PrintWriter out = response.getWriter(); | 
|---|
|  |  |  | out.write(result); | 
|---|
|  |  |  | out.write("SUCCESS"); | 
|---|
|  |  |  | out.flush(); | 
|---|
|  |  |  | out.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | competition.setStatus(3); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(competition.getStatus() == 2){ | 
|---|
|  |  |  | //添加勋章数据 | 
|---|
|  |  |  | List<PaymentCompetition> list = paymentCompetitionService.list(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("competitionId", competition.getId()).eq("payStatus", 2).eq("state", 1)); | 
|---|
|  |  |  | Set<Integer> collect = list.stream().map(PaymentCompetition::getAppUserId).collect(Collectors.toSet()); | 
|---|
|  |  |  | for (Integer integer : collect) { | 
|---|
|  |  |  | int count = paymentCompetitionService.count(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("appUserId", integer).eq("payStatus", 2).eq("state", 1)); | 
|---|
|  |  |  | StudentHonor studentHonor = new StudentHonor(); | 
|---|
|  |  |  | studentHonor.setAppUserId(integer); | 
|---|
|  |  |  | studentHonor.setHonorType(2); | 
|---|
|  |  |  | studentHonor.setNumber(count); | 
|---|
|  |  |  | studentHonorClient.saveStudentHonor(studentHonor); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | competition.setInsertTime(new Date()); | 
|---|
|  |  |  | cttService.save(competition); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | competition.setStatus(3); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(competition.getStatus() == 2){ | 
|---|
|  |  |  | //添加勋章数据 | 
|---|
|  |  |  | List<PaymentCompetition> list = paymentCompetitionService.list(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("competitionId", competition.getId()).eq("payStatus", 2).eq("state", 1)); | 
|---|
|  |  |  | Set<Integer> collect = list.stream().map(PaymentCompetition::getAppUserId).collect(Collectors.toSet()); | 
|---|
|  |  |  | for (Integer integer : collect) { | 
|---|
|  |  |  | int count = paymentCompetitionService.count(new QueryWrapper<PaymentCompetition>() | 
|---|
|  |  |  | .eq("appUserId", integer).eq("payStatus", 2).eq("state", 1)); | 
|---|
|  |  |  | StudentHonor studentHonor = new StudentHonor(); | 
|---|
|  |  |  | studentHonor.setAppUserId(integer); | 
|---|
|  |  |  | studentHonor.setHonorType(2); | 
|---|
|  |  |  | studentHonor.setNumber(count); | 
|---|
|  |  |  | studentHonorClient.saveStudentHonor(studentHonor); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | cttService.updateById(competition); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | String code = paymentCompetition.getCode(); | 
|---|
|  |  |  | Double amount = paymentCompetition.getAmount(); | 
|---|
|  |  |  | Competition competition = competitionService.getById(paymentCompetition.getCompetitionId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Store store = storeClient.queryStoreById(Integer.valueOf(competition.getStoreId().split(",")[0])); | 
|---|
|  |  |  | String payOrderNo = paymentCompetition.getPayOrderNo(); | 
|---|
|  |  |  | if (paymentCompetition.getPayType() == 1) {//微信支付 | 
|---|
|  |  |  | Map<String, String> map = payMoneyUtil.wxRefund(payOrderNo, code, amount.toString(), amount.toString(), "/base/competition/weChatCancelPaymentCompetitionCallback"); | 
|---|
|  |  |  | String return_code = map.get("return_code"); | 
|---|
|  |  |  | if (!"SUCCESS".equals(return_code)) { | 
|---|
|  |  |  | if (store.getOperatorId()!=null && store.getOperatorId()!=0){ | 
|---|
|  |  |  | String smidVx= storeClient.getmerchantNumberByOperatorId(store.getOperatorId()); | 
|---|
|  |  |  | if (!StringUtils.hasLength(smidVx)){ | 
|---|
|  |  |  | System.err.println("运营商未配置微信商户号,获取支付失败!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|---|
|  |  |  | String codeRefund = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5);// 退款单号 | 
|---|
|  |  |  | // 运营商退款 | 
|---|
|  |  |  | payMoneyUtil.weixinRefundV3(smidVx, codeRefund, pay.getPayOrderNo(), pay.getAmount().toString(), "/base/competition/weChatCancelPaymentCompetitionCallback1"); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | Map<String, String> map = payMoneyUtil.wxRefund(payOrderNo, code, amount.toString(), amount.toString(), | 
|---|
|  |  |  | "/base/competition/weChatCancelPaymentCompetitionCallback"); | 
|---|
|  |  |  | String return_code = map.get("return_code"); | 
|---|
|  |  |  | if (!"SUCCESS".equals(return_code)) { | 
|---|
|  |  |  | //                        return ResultUtil.error(map.get("return_msg")); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String refund_id = map.get("refund_id"); | 
|---|
|  |  |  | paymentCompetition.setRefundOrderNo(refund_id); | 
|---|
|  |  |  | paymentCompetition.setAppUserId(null); | 
|---|
|  |  |  | paymentCompetitionService.updateById(paymentCompetition); | 
|---|
|  |  |  | storeClient.addBackRecord(paymentCompetition.getAmount() + "_" + paymentCompetition.getAppUserId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String refund_id = map.get("refund_id"); | 
|---|
|  |  |  | paymentCompetition.setRefundOrderNo(refund_id); | 
|---|
|  |  |  | paymentCompetitionService.updateById(paymentCompetition); | 
|---|
|  |  |  | storeClient.addBackRecord(paymentCompetition.getAmount() + "_" + paymentCompetition.getAppUserId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (paymentCompetition.getPayType() == 2) {//支付宝支付 | 
|---|
|  |  |  | Map<String, String> map = payMoneyUtil.aliRefund(payOrderNo, amount.toString()); | 
|---|
|  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private StudentClient studentClient; | 
|---|
|  |  |  | @PostMapping("/base/competition/getPeopleFromId1") | 
|---|
|  |  |  | public List<CompetitionUser> getPeopleFromId1(@RequestBody GetPeopleQuery getPeopleQuery) { | 
|---|
|  |  |  | public Page<CompetitionUser> getPeopleFromId1(@RequestBody GetPeopleQuery getPeopleQuery) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Page<UserCompetition> participantPage = new Page<>(getPeopleQuery.getOffset(), getPeopleQuery.getLimit()); | 
|---|
|  |  |  | List<CompetitionUser> page = participantService.getPeopleFromId1(participantPage, getPeopleQuery.getId(), getPeopleQuery.getState()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<CompetitionUser> users = new ArrayList<>(); | 
|---|
|  |  |  | List<UserCompetition> coms = userCompetitionService.list(new QueryWrapper<UserCompetition>().eq("competitionId", getPeopleQuery.getId())); | 
|---|
|  |  |  | for (UserCompetition com : coms) { | 
|---|
|  |  |  | int number = com.getParticipantId(); | 
|---|
|  |  |  | String numberString = Integer.toString(number); | 
|---|
|  |  |  | int digitCount = numberString.length(); | 
|---|
|  |  |  | if (digitCount!=9){ | 
|---|
|  |  |  | TStudent tStudent = studentClient.queryById(number); | 
|---|
|  |  |  | CompetitionUser competitionUser = new CompetitionUser(); | 
|---|
|  |  |  | competitionUser.setName(tStudent.getName()); | 
|---|
|  |  |  | competitionUser.setPhone(tStudent.getPhone()); | 
|---|
|  |  |  | competitionUser.setSex(tStudent.getSex()); | 
|---|
|  |  |  | competitionUser.setIdCard(tStudent.getIdCard()); | 
|---|
|  |  |  | competitionUser.setState(tStudent.getState()); | 
|---|
|  |  |  | users.add(competitionUser); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | page.addAll(users); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Page<CompetitionUser> page = participantService.getPeopleFromId1(getPeopleQuery.getOffset(), getPeopleQuery.getLimit(), getPeopleQuery.getId(), getPeopleQuery.getState()); | 
|---|
|  |  |  | return page; | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|