From a540a342416302805adfb1599599bbbbaa191030 Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期五, 08 八月 2025 23:42:13 +0800 Subject: [PATCH] 赛事模块 --- cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java | 76 ++++++++++++++++++++++++++++++++++++-- 1 files changed, 72 insertions(+), 4 deletions(-) diff --git a/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java b/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java index d08d1cb..928158c 100644 --- a/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java +++ b/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java @@ -1,5 +1,6 @@ package com.dsh.account.controller; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.dsh.account.dto.BindDto; @@ -20,6 +21,7 @@ import com.dsh.account.model.LoginSMSCodeVo; import com.dsh.account.model.LoginWeChatVo; import com.dsh.account.model.QueryByNamePhone; +import com.dsh.account.model.query.UserDetailsOfSearch; import com.dsh.account.model.query.appUserQuery.QueryAppUser; import com.dsh.account.model.vo.QueryAppUserVO; import com.dsh.account.service.IVipPaymentService; @@ -32,6 +34,8 @@ import com.dsh.account.util.ResultUtil; import com.dsh.account.util.TokenUtil; import com.dsh.account.util.ToolUtil; +import com.dsh.account.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; @@ -46,7 +50,9 @@ import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import java.io.BufferedReader; import java.io.PrintWriter; +import java.nio.charset.StandardCharsets; import java.util.ArrayList; import java.util.Date; import java.util.List; @@ -198,7 +204,8 @@ @ResponseBody @GetMapping("/base/appUser/getAppUserByPhone/{phone}") public TAppUser getAppUserByPhone(@PathVariable("phone") String phone) { - TAppUser appUser = appUserService.getOne(new QueryWrapper<TAppUser>().eq("phone", phone)); + TAppUser appUser = appUserService.getOne(new QueryWrapper<TAppUser>().eq("phone", phone) + .eq("state",1)); return appUser; } @@ -290,8 +297,7 @@ @ResponseBody @PostMapping("/base/appUser/loginSMSCode") @ApiOperation(value = "短信验证码登录", tags = {"APP-登录注册"}) - @ApiImplicitParams({ - }) + public ResultUtil<String> loginSMSCode(LoginSMSCodeVo loginSMSCodeVo) { try { return appUserService.loginSMSCode(loginSMSCodeVo); @@ -453,6 +459,51 @@ /** + * 购买年度会员支付微信回调V3版本回调 + * + * @param request + * @param response + */ + @ResponseBody + @PostMapping("/base/appUser/addVipPaymentWeChatCallback1") + public void addVipPaymentWeChatCallback1(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 out_trade_no = jsonInfo.getString("out_trade_no"); + String transaction_id = jsonInfo.getString("transaction_id"); + String trade_state = jsonInfo.getString("trade_state"); + if (trade_state.equals("SUCCESS")) { + ResultUtil resultUtil = vipPaymentService.addVipPaymentCallback(out_trade_no, transaction_id); + if (resultUtil.getCode() == 200) { + PrintWriter out = response.getWriter(); + out.write("SUCCESS"); + out.flush(); + out.close(); + } + } + } catch (Exception e) { + e.printStackTrace(); + } + } + /** * 购买年度会员支付微信回调 * * @param request @@ -479,7 +530,6 @@ e.printStackTrace(); } } - /** * 购买年度会员支付支付宝回调 @@ -676,4 +726,22 @@ List<TAppUser> list = appUserService.list(queryWrapper); return list.stream().map(TAppUser::getId).collect(Collectors.toList()); } + + + @PostMapping("/appUser/queryAppUserByIds") + @ResponseBody + public List<TAppUser> queryAppUserByIds(@RequestBody UserDetailsOfSearch search){ + LambdaQueryWrapper<TAppUser> tAppUserLambdaQueryWrapper = new LambdaQueryWrapper<>(); + if(ToolUtil.isNotEmpty(search.getIdCard())){ + tAppUserLambdaQueryWrapper.eq(TAppUser::getIdCard, search.getIdCard()); + } + if(ToolUtil.isNotEmpty(search.getPhone())){ + tAppUserLambdaQueryWrapper.eq(TAppUser::getPhone, search.getPhone()); + } + if(ToolUtil.isNotEmpty(search.getName())){ + tAppUserLambdaQueryWrapper.eq(TAppUser::getName, search.getName()); + } + tAppUserLambdaQueryWrapper.in(TAppUser::getId,search.getUseIds()); + return appUserService.list(tAppUserLambdaQueryWrapper); + } } -- Gitblit v1.7.1