From 9a42cbae72259034a6cbe3a827d168a3a6f65154 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期五, 02 六月 2023 08:34:42 +0800 Subject: [PATCH] 新增加司机提现分账逻辑 --- driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/DriverServiceImpl.java | 197 ++++++++++++++++++++++++++++++++----------------- 1 files changed, 128 insertions(+), 69 deletions(-) diff --git a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/DriverServiceImpl.java b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/DriverServiceImpl.java index 731626c..d0e7e06 100644 --- a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/DriverServiceImpl.java +++ b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/DriverServiceImpl.java @@ -13,11 +13,12 @@ import com.supersavedriving.driver.modular.system.service.*; import com.supersavedriving.driver.modular.system.dao.DriverMapper; import com.supersavedriving.driver.modular.system.util.*; -import com.supersavedriving.driver.modular.system.util.MallBook.model.InterfaceResponse; -import com.supersavedriving.driver.modular.system.util.MallBook.model.Register; +import com.supersavedriving.driver.modular.system.util.MallBook.model.*; import com.supersavedriving.driver.modular.system.util.MallBook.util.TrhRequest; import com.supersavedriving.driver.modular.system.util.mongodb.model.Location; import com.supersavedriving.driver.modular.system.util.rongyun.RongYunUtil; +import com.supersavedriving.driver.modular.system.util.weChat.WeChatUtil; +import com.supersavedriving.driver.modular.system.util.weChat.model.Code2Session; import com.supersavedriving.driver.modular.system.warpper.*; import org.apache.shiro.authc.SimpleAuthenticationInfo; import org.apache.shiro.authc.UsernamePasswordToken; @@ -40,6 +41,7 @@ import org.springframework.web.context.request.ServletRequestAttributes; import javax.servlet.http.HttpServletRequest; +import java.net.InetAddress; import java.text.SimpleDateFormat; import java.util.*; @@ -101,8 +103,17 @@ @Autowired private PushUtil pushUtil; + @Autowired + private WeChatUtil weChatUtil; + @Value("${callbackPath}") private String callbackPath; + + @Value("${wx.appletsAppid}") + private String appletsAppid; + + @Value("${alipay.appid}") + private String appid; @@ -678,84 +689,131 @@ rechargeRecord.setAgentId(driver.getAgentId()); rechargeRecordService.insert(rechargeRecord); + PaymentOrder paymentOrder = new PaymentOrder(); + paymentOrder.setBizOrderId(out_trade_no); + paymentOrder.setAmount(String.valueOf(Double.valueOf(amount * 100).intValue())); + paymentOrder.setOrderName("账户充值"); + paymentOrder.setPayType("WX_MINI"); + paymentOrder.setTransferType("0"); + paymentOrder.setAsynSplitFlag("1"); + paymentOrder.setAppid(appletsAppid); + paymentOrder.setOpenid(driver.getOpenid()); + paymentOrder.setTerminalIp(InetAddress.getLocalHost().getHostAddress()); + List<PaymentOrderGood> goodsDetail = new ArrayList<>(); + PaymentOrderGood paymentOrderGood = new PaymentOrderGood(); + paymentOrderGood.setGoodsName("充值"); + goodsDetail.add(paymentOrderGood); + paymentOrder.setGoodsDetail(goodsDetail); + paymentOrder.setFrontUrl("http://www.baidu.com");//前端回调地址 + paymentOrder.setNotifyUrl(callbackPath + "/base/driver/balanceRechargeCallback"); + paymentOrder.setParameter1(out_trade_no); - ResultUtil weixinpay = payMoneyUtil.weixinpay("余额充值", "", out_trade_no, amount.toString(), "/base/driver/balanceRechargeCallback", "APP"); - new Thread(new Runnable() { - @Override - public void run() { - try { - int num = 1; - int wait = 0; - while (num <= 10){ - int min = 5000; - wait += (min * num); - RechargeRecord rechargeRecord1 = rechargeRecordService.selectOne(new EntityWrapper<RechargeRecord>().eq("code", out_trade_no)); - if(rechargeRecord1.getPayStatus() != 1){ - return; - } - - /** - * SUCCESS--支付成功 - * REFUND--转入退款 - * NOTPAY--未支付 - * CLOSED--已关闭 - * REVOKED--已撤销(刷卡支付) - * USERPAYING--用户支付中 - * PAYERROR--支付失败(其他原因,如银行返回失败) - * ACCEPT--已接收,等待扣款 - */ - ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(out_trade_no, ""); - if(resultUtil.getCode() == 200){ - Map<String, String> map = resultUtil.getData(); - String trade_type = map.get("trade_type"); - String trade_state = map.get("trade_state"); - String transaction_id = map.get("transaction_id"); - if("REFUND".equals(trade_state) || "NOTPAY".equals(trade_state) || "CLOSED".equals(trade_state) || "REVOKED".equals(trade_state) || "PAYERROR".equals(trade_state)){ - rechargeRecordService.deleteById(rechargeRecord1.getId()); + TrhRequest<PaymentOrder> request = new TrhRequest(); + InterfaceResponse execute = request.execute(paymentOrder, PaymentOrder.SERVICE_CODE); + if(!"0000".equals(execute.getCode())){ + return ResultUtil.error(execute.getMsg()); + } + JSONObject jsonObject = JSON.parseObject(execute.getResult()); + String status = jsonObject.getString("status"); + if("2".equals(status)){ + return ResultUtil.error("失败"); + } + String payCode = jsonObject.getString("payCode"); + if(ToolUtil.isNotEmpty(payCode)){ + new Thread(new Runnable() { + @Override + public void run() { + try { + int num = 1; + int wait = 0; + while (num <= 10){ + int min = 5000; + wait += (min * num); + RechargeRecord rechargeRecord1 = rechargeRecordService.selectOne(new EntityWrapper<RechargeRecord>().eq("code", out_trade_no)); + if(rechargeRecord1.getPayStatus() != 1){ return; } - if("SUCCESS".equals(trade_state)){ - Driver driver1 = DriverServiceImpl.this.selectById(uid); - AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); - accountChangeDetail.setUserType(2); - accountChangeDetail.setUserId(uid); - accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); - accountChangeDetail.setChangeType(3); - accountChangeDetail.setType(1); - accountChangeDetail.setCreateTime(new Date()); - accountChangeDetail.setExplain("余额充值"); - accountChangeDetail.setOldData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); - driver1.setBalance(driver1.getBalance() + amount); - accountChangeDetail.setNewData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); - DriverServiceImpl.this.updateById(driver1); - accountChangeDetailService.saveData(accountChangeDetail); + QueryOrder queryOrder = new QueryOrder(); + /** + * 原请求订单号(必填) 字段长度最长:32位 + */ + queryOrder.setOriginalMerOrderId(out_trade_no); + /** + * 1:支付查询 2:退款查询 3:确认收货查询 4:结算查询 5:充值查询 6:转账查询 7:异步分账查询(必填) 字段长度最长:1位 + */ + queryOrder.setQueryType("1"); + TrhRequest<QueryOrder> request = new TrhRequest(); + InterfaceResponse execute1 = request.execute(queryOrder, QueryOrder.SERVICE_CODE); + if("0000".equals(execute1.getCode())){ + JSONObject jsonObject1 = JSON.parseObject(execute1.getResult()); + String status1 = jsonObject1.getString("status"); + if("0".equals(status1)){//待处理 + Thread.sleep(wait); + num++; + } + if("1".equals(status1)){//成功 + String merOrderId = jsonObject1.getString("merOrderId"); + Driver driver1 = DriverServiceImpl.this.selectById(rechargeRecord1.getUserId()); + AccountChangeDetail accountChangeDetail = new AccountChangeDetail(); + accountChangeDetail.setUserType(2); + accountChangeDetail.setUserId(driver1.getId()); + accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3)); + accountChangeDetail.setChangeType(3); + accountChangeDetail.setType(1); + accountChangeDetail.setCreateTime(new Date()); + accountChangeDetail.setExplain("账户充值"); + accountChangeDetail.setOldData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); + driver1.setBalance(driver1.getBalance() + rechargeRecord1.getAmount()); + accountChangeDetail.setNewData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); + DriverServiceImpl.this.updateById(driver1); + accountChangeDetailService.saveData(accountChangeDetail); - rechargeRecord1.setPayTime(new Date()); - rechargeRecord1.setPayStatus(2); - rechargeRecord1.setOrderNumber(transaction_id); - rechargeRecordService.updateById(rechargeRecord1); - return; - } - if("USERPAYING".equals(trade_state) || "ACCEPT".equals(trade_state)){ + rechargeRecord1.setPayTime(new Date()); + rechargeRecord1.setPayStatus(2); + rechargeRecord1.setOrderNumber(merOrderId); + rechargeRecord1.setSurplusDividedAmount(rechargeRecord1.getAmount()); + rechargeRecordService.updateById(rechargeRecord1); + break; + } + if("2".equals(status1) || 10 == num){//失败 + rechargeRecordService.deleteById(rechargeRecord1.getId()); + break; + } + }else{ Thread.sleep(wait); num++; } - }else{ - Thread.sleep(wait); - num++; } - if(10 == num){ - rechargeRecordService.deleteById(rechargeRecord1.getId()); - } + }catch (Exception e){ + e.printStackTrace(); } - }catch (Exception e){ - e.printStackTrace(); } - } - }).start(); - return weixinpay; + }).start(); + } + return ResultUtil.success(payCode); } + + /** + * 司机端跳小程序支付 + * @param driverId + * @param jscode + * @param amount + * @return + * @throws Exception + */ + @Override + public ResultUtil balanceRecharge1(Integer driverId, String jscode, Double amount) throws Exception { + Code2Session code2Session = weChatUtil.code2Session(jscode); + if(null != code2Session.getErrcode() && code2Session.getErrcode() != 0){ + return ResultUtil.error(code2Session.getErrmsg()); + } + String openid = code2Session.getOpenid(); + Driver driver = this.selectById(driverId); + driver.setOpenid(openid); + this.updateById(driver); + return balanceRecharge(driverId, amount); + } /** * 充值回调通知逻辑处理 @@ -776,7 +834,7 @@ accountChangeDetail.setChangeType(3); accountChangeDetail.setType(1); accountChangeDetail.setCreateTime(new Date()); - accountChangeDetail.setExplain("余额充值"); + accountChangeDetail.setExplain("账户充值"); accountChangeDetail.setOldData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); driver1.setBalance(driver1.getBalance() + rechargeRecord1.getAmount()); accountChangeDetail.setNewData(driver1.getBalance() + driver1.getBackgroundBalance() + driver1.getCouponBalance() + driver1.getCommission()); @@ -786,6 +844,7 @@ rechargeRecord1.setPayTime(new Date()); rechargeRecord1.setPayStatus(2); rechargeRecord1.setOrderNumber(transaction_id); + rechargeRecord1.setSurplusDividedAmount(rechargeRecord1.getAmount()); rechargeRecordService.updateById(rechargeRecord1); } -- Gitblit v1.7.1