YqPayController.java 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654
  1. package com.ym.mec.collectfee.controller;
  2. import com.alibaba.druid.sql.visitor.functions.Now;
  3. import com.alibaba.fastjson.JSON;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.ym.mec.collectfee.common.sms.SmsExample;
  6. import com.ym.mec.collectfee.common.web.BaseController;
  7. import com.ym.mec.collectfee.entity.*;
  8. import com.ym.mec.collectfee.service.*;
  9. import com.ym.mec.collectfee.utils.Constants;
  10. import com.ym.mec.collectfee.utils.GenerateNum;
  11. import com.ym.mec.collectfee.utils.ShortUrlUtil;
  12. import com.ym.mec.collectfee.utils.yqpay.*;
  13. import lombok.extern.slf4j.Slf4j;
  14. import org.apache.commons.io.IOUtils;
  15. import org.slf4j.Logger;
  16. import org.slf4j.LoggerFactory;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.core.io.ClassPathResource;
  19. import org.springframework.http.HttpStatus;
  20. import org.springframework.scheduling.annotation.EnableScheduling;
  21. import org.springframework.scheduling.annotation.Scheduled;
  22. import org.springframework.transaction.annotation.Transactional;
  23. import org.springframework.validation.annotation.Validated;
  24. import org.springframework.web.bind.annotation.ModelAttribute;
  25. import org.springframework.web.bind.annotation.PostMapping;
  26. import org.springframework.web.bind.annotation.RequestMapping;
  27. import org.springframework.web.bind.annotation.RestController;
  28. import java.io.InputStreamReader;
  29. import java.lang.reflect.Array;
  30. import java.math.BigDecimal;
  31. import java.text.SimpleDateFormat;
  32. import java.time.LocalDateTime;
  33. import java.util.*;
  34. //@Api("支付")
  35. @Slf4j
  36. @RestController
  37. @RequestMapping("yqpay")
  38. @EnableScheduling // 2.开启定时任务
  39. public class YqPayController extends BaseController {
  40. protected final Logger logger = LoggerFactory.getLogger(this.getClass());
  41. @Autowired
  42. private YqPayService yqPayService;
  43. @Autowired
  44. private YqQueryService yqQueryService;
  45. @Autowired
  46. private OrderService orderService;
  47. @Autowired
  48. private AccountService accountService;
  49. @Autowired
  50. private CourseGroupInfoService CourseGroupInfoService;
  51. @Autowired
  52. private ApplyInfoService applyInfoService;
  53. @Autowired
  54. private RenewalsService renewalsService;
  55. @Autowired
  56. private SchoolService schoolService;
  57. /**
  58. * 统一下单(乐团缴费)
  59. *
  60. * @return String
  61. * @throws Exception
  62. */
  63. // @ApiOperation(value = "提交支付", notes = "易乾支付统一下单")
  64. @PostMapping("/toPay")
  65. @Transactional(rollbackFor = Exception.class)
  66. public Object toPay(@ModelAttribute @Validated Order order) throws Exception {
  67. BigDecimal amount = new BigDecimal("0");
  68. School school = schoolService.get(order.getClassId());
  69. //计划招生人数有更新,更新
  70. orderService.getSchoolDetail(school.getSchoolId());
  71. Order userOrder = orderService.findOrderByStatus(order.getUserId(), 2);
  72. if (userOrder != null) {
  73. return failed("您已支付成功,请勿重复支付");
  74. }
  75. //判断用户是否已存在订单
  76. userOrder = orderService.findOrderByStatus(order.getUserId(), 1);
  77. if (userOrder != null) {
  78. return failed(HttpStatus.CONTINUE, "您有待支付的订单");
  79. }
  80. //1、判断已报名人数
  81. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getCourseId());
  82. if (courseGroupInfo.getRegNum().compareTo(courseGroupInfo.getPlanNum()) >= 0) {
  83. Integer nums = orderService.getPayingOrderNums(order.getCourseId());
  84. if (nums != null && nums > 0) {
  85. return failed(HttpStatus.FORBIDDEN, "当前排队人数" + nums + "人,请您耐心等待");
  86. } else {
  87. return succeed("招生人数已满!");
  88. }
  89. }
  90. //课程组价格
  91. BigDecimal courseFee = courseGroupInfo.getFeeAmount();
  92. amount = amount.add(courseFee);
  93. //获取乐器的价格
  94. ClassPathResource classPathResource = new ClassPathResource("instruments.json"); //解析乐器数据
  95. BigDecimal instrumentPrice = new BigDecimal("0");//乐器价格
  96. String instrumentName = "";//乐器名称
  97. String instrumentId = order.getInstrument();
  98. String jsonString = IOUtils.toString(new InputStreamReader(classPathResource.getInputStream(), "UTF-8"));
  99. Instrument instrument = JSONObject.parseObject(jsonString, Instrument.class);
  100. if (order.getInstrument() != null && !order.getInstrument().isEmpty()) {
  101. instrumentPrice = new BigDecimal(instrument.getInstruments().get(instrumentId).get("referencePrice"));
  102. instrumentName = (String) instrument.getInstruments().get(instrumentId).get("index") + "-" +
  103. (String) instrument.getInstruments().get(instrumentId).get("name");
  104. }
  105. //2 版本为3.0( 26),不收乐器费用,收押金800放乐器费用
  106. if (courseGroupInfo.getFeeType().equals(26)) {
  107. instrumentPrice = new BigDecimal("800");
  108. }
  109. amount = amount.add(instrumentPrice);
  110. //辅件价格
  111. String adjunctIds = order.getAdjunct();
  112. BigDecimal adjunctPrice = new BigDecimal("0");//辅件价格
  113. String adjunctName = "";//辅件名称
  114. if (adjunctIds != null && !adjunctIds.isEmpty()) {
  115. String[] adjunctIdArr = adjunctIds.split(",");
  116. for (String adjunctId : adjunctIdArr) {
  117. adjunctPrice = adjunctPrice.add(new BigDecimal(instrument.getAuxiliaries().get(adjunctId).get("referencePrice")));
  118. adjunctName += (String) instrument.getAuxiliaries().get(adjunctId).get("name") + "|";
  119. }
  120. }
  121. amount = amount.add(adjunctPrice);
  122. ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  123. order.setPoName(school.getName());
  124. order.setVoicyPart(courseGroupInfo.getSubName());
  125. order.setGroupId(courseGroupInfo.getId());
  126. order.setAmount(amount);
  127. order.setRemark(instrumentName);
  128. order.setTuiFee(courseFee);
  129. order.setGoodsFee(instrumentPrice);
  130. order.setSdName(adjunctName + "教材|琴谱");
  131. order.setSdFee(adjunctPrice);
  132. order.setType(1);
  133. order.setUserName(applyInfo.getName());
  134. String orderNo = GenerateNum.getInstance().GenerateOrderNo(); //自己系统订单号
  135. order.setOrderNo(orderNo);
  136. order.setCreateTime(new Date()); //订单提交时间
  137. order.setStatus(1); //订单状态
  138. //获取分佣账户
  139. Integer branchId = 1001;//order.getBranchId();
  140. Account routingAccount = accountService.getRoutingAccount(branchId, amount);
  141. order.setAccount(routingAccount.getSellerNo());
  142. order.setUAccount(routingAccount.getId().toString());
  143. //1、插入订单
  144. orderService.insert(order);
  145. //2、修改已报名人数
  146. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() + 1);
  147. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  148. //3、修改分佣账户已收金额
  149. BigDecimal HasRouting = routingAccount.getHasRouting().add(order.getAmount());
  150. routingAccount.setHasRouting(HasRouting);
  151. accountService.upByIdAndVersion(routingAccount);
  152. Map rqMap = orderService.getPayMap(routingAccount, order, school); //获取支付map
  153. return succeed(rqMap);
  154. }
  155. /**
  156. * 重新支付订单
  157. *
  158. * @param order
  159. * @return
  160. * @throws Exception
  161. */
  162. @PostMapping("/rePay")
  163. @Transactional(rollbackFor = Exception.class)
  164. public Object rePay(@ModelAttribute @Validated Order order) throws Exception {
  165. BigDecimal amount = new BigDecimal("0");
  166. School school = schoolService.get(order.getClassId());
  167. Order userOrder = orderService.findOrderByStatus(order.getUserId(), 2);
  168. if (userOrder != null) {
  169. return failed("您已支付成功,请勿重复支付");
  170. }
  171. //判断用户是否已存在订单
  172. userOrder = orderService.findOrderByStatus(order.getUserId(), 1);
  173. if (userOrder == null) {
  174. return failed("您没有支付中的订单,请勿非法请求");
  175. }
  176. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getCourseId());
  177. //课程组价格
  178. BigDecimal courseFee = courseGroupInfo.getFeeAmount();
  179. amount = amount.add(courseFee);
  180. //获取乐器的价格
  181. ClassPathResource classPathResource = new ClassPathResource("instruments.json"); //解析乐器数据
  182. BigDecimal instrumentPrice = new BigDecimal("0");//乐器价格
  183. String instrumentName = "";//乐器名称
  184. String instrumentId = order.getInstrument();
  185. String jsonString = IOUtils.toString(new InputStreamReader(classPathResource.getInputStream(), "UTF-8"));
  186. Instrument instrument = JSONObject.parseObject(jsonString, Instrument.class);
  187. if (order.getInstrument() != null && !order.getInstrument().isEmpty()) {
  188. instrumentPrice = new BigDecimal(instrument.getInstruments().get(instrumentId).get("referencePrice"));
  189. instrumentName = (String) instrument.getInstruments().get(instrumentId).get("index") + "-" +
  190. (String) instrument.getInstruments().get(instrumentId).get("name");
  191. }
  192. //2 版本为3.0( 26),不收乐器费用,收押金800放乐器费用
  193. if (courseGroupInfo.getFeeType().equals(26)) {
  194. instrumentPrice = new BigDecimal("800");
  195. }
  196. amount = amount.add(instrumentPrice);
  197. //辅件价格
  198. String adjunctIds = order.getAdjunct();
  199. BigDecimal adjunctPrice = new BigDecimal("0");//辅件价格
  200. String adjunctName = "";//辅件名称
  201. if (adjunctIds != null && !adjunctIds.isEmpty()) {
  202. String[] adjunctIdArr = adjunctIds.split(",");
  203. for (String adjunctId : adjunctIdArr) {
  204. adjunctPrice = adjunctPrice.add(new BigDecimal(instrument.getAuxiliaries().get(adjunctId).get("referencePrice")));
  205. adjunctName += (String) instrument.getAuxiliaries().get(adjunctId).get("name") + "|";
  206. }
  207. }
  208. amount = amount.add(adjunctPrice);
  209. ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  210. order.setPoName(school.getName());
  211. order.setVoicyPart(courseGroupInfo.getSubName());
  212. order.setGroupId(courseGroupInfo.getId());
  213. order.setAmount(amount);
  214. order.setRemark(instrumentName);
  215. order.setTuiFee(courseFee);
  216. order.setGoodsFee(instrumentPrice);
  217. order.setSdName(adjunctName + "教材|琴谱");
  218. order.setSdFee(adjunctPrice);
  219. order.setType(1);
  220. order.setUserName(applyInfo.getName());
  221. String orderNo = GenerateNum.getInstance().GenerateOrderNo(); //自己系统订单号
  222. order.setOrderNo(orderNo);
  223. order.setCreateTime(new Date()); //订单提交时间
  224. order.setStatus(1); //订单状态
  225. //获取分佣账户
  226. int accountId = Integer.parseInt(userOrder.getUAccount());
  227. Account routingAccount = accountService.get(accountId);
  228. order.setAccount(userOrder.getAccount());
  229. order.setUAccount(userOrder.getUAccount());
  230. //1.关闭订单
  231. HashMap<String, Object> upMap = new HashMap<>();
  232. upMap.put("status",0);
  233. upMap.put("oldStatus",1);
  234. upMap.put("id",userOrder.getId());
  235. orderService.updateByIdAndStatus(upMap);
  236. //2、插入订单
  237. orderService.insert(order);
  238. //3、修改已报名人数
  239. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() + 1);
  240. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  241. //4、修改分佣账户已收金额
  242. BigDecimal HasRouting = routingAccount.getHasRouting().add(order.getAmount()).subtract(userOrder.getAmount());
  243. routingAccount.setHasRouting(HasRouting);
  244. accountService.upByIdAndVersion(routingAccount);
  245. Map rqMap = orderService.getPayMap(routingAccount, order, school); //获取支付map
  246. return succeed(rqMap);
  247. }
  248. /**
  249. * 续费支付
  250. *
  251. * @return String
  252. * @throws Exception
  253. */
  254. // @ApiOperation(value = "续费支付", notes = "续费支付")
  255. @PostMapping("/renewalsPay")
  256. public Object renewalsPay(@ModelAttribute @Validated Renewals renewals) throws Exception {
  257. MecUser mecUser = applyInfoService.findMecUser(renewals.getUserId());
  258. if (mecUser == null) {
  259. return failed("续费用户不存在");
  260. }
  261. renewals.setBranchId(mecUser.getBranchId());
  262. //课程组价格
  263. List<MecCourse> courses = applyInfoService.queryUserCourse(renewals.getUserId());//获取续费课程
  264. if (courses == null) {
  265. return failed("您没有续费的课程");
  266. }
  267. MecCourse mecCourse4json = JSON.parseObject(renewals.getCourses(), MecCourse.class);
  268. if (mecCourse4json == null) {
  269. return failed("请选择续费课程");
  270. }
  271. //classType 小课1 大课2
  272. Integer buyCount = mecCourse4json.getBuyCount();
  273. if (buyCount <= 0 || buyCount > 20) {
  274. return failed("购买课程次数不能小于1,大于20");
  275. }
  276. BigDecimal amount = new BigDecimal("0"); //课程总价
  277. String remark = "";
  278. List<MecCourse> pickCourses = new ArrayList<>();
  279. for (int i = 0; i < courses.size(); i++) {
  280. MecCourse course = courses.get(i);
  281. if (mecCourse4json.getCourseId().equals(course.getCourseId().intValue())) {
  282. BigDecimal price = course.getClassType().equals(1) ? course.getPrice().multiply(BigDecimal.valueOf(buyCount)) : course.getPrice().multiply(BigDecimal.valueOf(course.getBuyCount()));
  283. amount = amount.add(price);
  284. remark += course.getClassName();
  285. if (course.getClassType().equals(1)) {
  286. course.setBuyCount(buyCount);
  287. }
  288. pickCourses.add(course);
  289. }
  290. }
  291. if (pickCourses.size() == 0) {
  292. return failed("请选择续费课程");
  293. }
  294. String orderNo = GenerateNum.getInstance().GenerateOrderNo(); //自己系统订单号
  295. //获取分佣账户
  296. Integer branchId = 1001;//order.getBranchId();
  297. Account routingAccount = accountService.getRoutingAccount(branchId, amount);
  298. Order order = renewalsService.addRenewalsOrder(renewals, amount, orderNo, pickCourses, routingAccount, remark);
  299. Map rqMap = orderService.getPayMap(routingAccount, order, null); //获取支付map
  300. return succeed(rqMap);
  301. }
  302. /**
  303. * 交易查询
  304. *
  305. * @param merOrderNoList 用户订单号
  306. * @return
  307. * @throws Exception
  308. */
  309. //@PostMapping("/query")
  310. //@Scheduled(cron = "0/3 40 11 * * ?")
  311. public Object query(String merOrderNoList) throws Exception {
  312. String notifyUrl = ""; //回调地址
  313. Map<String, Object> resultMap = new LinkedHashMap<>();
  314. resultMap.put("merOrderNoList", merOrderNoList);
  315. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  316. return yqQueryService.orderQuery(requestMap);
  317. }
  318. /**
  319. * 用户信息(商户)查询
  320. *
  321. * @param sonMerNo 子商户号
  322. * @return
  323. * @throws Exception
  324. */
  325. @PostMapping("/queryaccount")
  326. public String queryAccount(String sonMerNo) throws Exception {
  327. String notifyUrl = ""; //回调地址
  328. Map<String, Object> resultMap = new LinkedHashMap<>();
  329. resultMap.put("merOrderNoList", sonMerNo);
  330. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  331. return yqQueryService.queryAccount(requestMap);
  332. }
  333. /**
  334. * 对账查询(定时任务每天对账)
  335. *
  336. * @return
  337. */
  338. public String queryBill() throws Exception {
  339. String notifyUrl = ""; //回调地址
  340. Map<String, Object> resultMap = new LinkedHashMap<>();
  341. resultMap.put("tradeDate", ""); //交易日期
  342. resultMap.put("payState", ""); //订单状态
  343. resultMap.put("tradeType", ""); //交易类型,不填为全部
  344. resultMap.put("channelType", ""); //通道类型,不填为全部
  345. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  346. return yqQueryService.billQuery(requestMap);
  347. }
  348. /**
  349. * 平台转账
  350. *
  351. * @return
  352. * @throws Exception
  353. */
  354. @PostMapping("/platformtransferacc")
  355. public String platformTransferAcc() throws Exception {
  356. String notifyUrl = ""; //回调地址
  357. Map<String, Object> resultMap = new LinkedHashMap<>();
  358. resultMap.put("payeeNo", ""); //收款方商户号
  359. resultMap.put("payeeName", ""); //收款方姓名
  360. resultMap.put("amount", ""); //金额
  361. resultMap.put("merOrderNo", ""); //商户订单号
  362. resultMap.put("remarks", ""); //备注
  363. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  364. return yqPayService.platformTransferAcc(requestMap);
  365. }
  366. /**
  367. * 提现短信
  368. *
  369. * @return
  370. * @throws Exception
  371. */
  372. @PostMapping("/sendsms")
  373. public Msg sendSms(@ModelAttribute Intfc intfc) throws Exception {
  374. String notifyUrl = ""; //回调地址
  375. String merMerOrderNo = GenerateNum.getInstance().GenerateOrderNo();
  376. Map<String, Object> resultMap = new LinkedHashMap<>();
  377. resultMap.put("wdMerNo", intfc.getWdMerNo()); //提现商户号
  378. resultMap.put("merMerOrderNo", merMerOrderNo); //商户订单号
  379. resultMap.put("amount", intfc.getAmount()); //提现金额
  380. resultMap.put("cardNo", intfc.getCardNo()); //提现银行卡号
  381. // resultMap.put("phone", intfc.getPhone()); //预留手机号(选填)
  382. // resultMap.put("cardType", intfc.getCardType()); //卡类型 0-个人银行卡,1-企业银行卡。(选填)
  383. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  384. return yqPayService.intfc(requestMap);
  385. }
  386. /**
  387. * 提现
  388. *
  389. * @return
  390. * @throws Exception
  391. */
  392. @PostMapping("/intfc")
  393. public Msg intfc(@ModelAttribute Intfc intfc) throws Exception {
  394. String notifyUrl = "http://47.99.212.176:9000/yqpay/notify"; //回调地址
  395. String merMerOrderNo = GenerateNum.getInstance().GenerateOrderNo();
  396. Map<String, Object> resultMap = new LinkedHashMap<>();
  397. resultMap.put("wdMerNo", intfc.getWdMerNo()); //提现商户号
  398. resultMap.put("merMerOrderNo", merMerOrderNo); //商户订单号
  399. resultMap.put("amount", intfc.getAmount()); //提现金额
  400. resultMap.put("cardNo", intfc.getCardNo()); //提现银行卡号
  401. // resultMap.put("phone", intfc.getPhone()); //预留手机号(选填)
  402. // resultMap.put("cardType", intfc.getCardType()); //卡类型 0-个人银行卡,1-企业银行卡。(选填)
  403. resultMap.put("seqNo", ""); //流水号(选填)
  404. resultMap.put("smsCode", ""); //验证码(选填)
  405. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  406. return yqPayService.intfc(requestMap);
  407. }
  408. /**
  409. * 易乾异步通知接口
  410. *
  411. * @param msg
  412. * @return String
  413. * @throws Exception
  414. */
  415. @PostMapping("/notify")
  416. public Msg notify(@ModelAttribute Msg msg) throws Exception {
  417. logger.info(msg.toString());
  418. Map<String, Object> rqMap = new LinkedHashMap<String, Object>();
  419. rqMap.put("code", msg.getCode());
  420. rqMap.put("msg", msg.getMsg());
  421. rqMap.put("responseType", msg.getResponseType());
  422. rqMap.put("responseParameters", msg.getResponseParameters());
  423. rqMap.put("sign", msg.getSign());
  424. boolean rs = YqPayUtil.verify(rqMap);
  425. msg.setMsg("fail");
  426. Map<String, String> notifyMap = new HashMap<>();
  427. if (rs) {
  428. notifyMap = JSON.parseObject(msg.getResponseParameters(), Map.class);
  429. }
  430. //支付中订单存在,更新状态
  431. if (msg.getResponseType().equals("1") && notifyMap.size() > 0) {
  432. String tradeState = msg.getCode().equals("88") ? "1" : "0";
  433. notifyMap.put("tradeState", tradeState);
  434. notifyMap.put("totalMoney", notifyMap.get("payAmount"));
  435. notifyMap.put("merOrderNo", notifyMap.get("merMerOrderNo"));
  436. this.updateOrder(notifyMap);
  437. msg.setCode("000000");
  438. msg.setMsg("success");
  439. }
  440. return msg;
  441. }
  442. @Scheduled(cron = "0/5 * * * * ?")
  443. //@RequestMapping("/getOrderStatus")
  444. public void getOrderStatus() throws Exception {
  445. List<Order> payingOrders = orderService.findPayingOrders();
  446. String merOrderNos = ""; //
  447. ArrayList<String> orderNoList = new ArrayList<String>();
  448. for (Order payingOrder : payingOrders) {
  449. String orderNo = payingOrder.getOrderNo();
  450. orderNoList.add(orderNo);
  451. merOrderNos += orderNo + ",";
  452. }
  453. if (merOrderNos.isEmpty()) {
  454. return;
  455. }
  456. merOrderNos = merOrderNos.substring(0, merOrderNos.length() - 1);
  457. String notifyUrl = ""; //回调地址
  458. Map<String, Object> resultMap = new LinkedHashMap<>();
  459. resultMap.put("merOrderNoList", merOrderNos);
  460. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  461. Msg queryRs = yqQueryService.orderQuery(requestMap);
  462. logger.info("查询易乾结果" + queryRs.toString());
  463. if (queryRs.getCode().equals("88")) {
  464. //更新订单状态
  465. String[] statusArr = {"0", "1", "7"};
  466. String responseParameters = queryRs.getResponseParameters();
  467. List<Map<String, String>> responseList = JSON.parseObject(responseParameters, List.class);
  468. for (Map<String, String> response : responseList) {
  469. Map<String, String> rpMap = response;
  470. if (Arrays.asList(statusArr).contains(rpMap.get("tradeState"))) {
  471. this.updateOrder(rpMap);
  472. }
  473. if (orderNoList.contains(rpMap.get("merOrderNo"))) {
  474. orderNoList.remove(rpMap.get("merOrderNo"));
  475. }
  476. }
  477. this.failOrders(orderNoList);
  478. }
  479. }
  480. @Transactional(rollbackFor = Exception.class)
  481. public void updateOrder(Map<String, String> rpMap) throws Exception {
  482. int status = rpMap.get("tradeState").equals("1") ? 2 : 0;
  483. Order order = orderService.getOrderByOrderNo(rpMap.get("merOrderNo"));
  484. if (order == null) {
  485. return;
  486. }
  487. HashMap<String, Object> upMap = new HashMap<>();
  488. upMap.put("id", order.getId());
  489. upMap.put("oldStatus", 1);
  490. upMap.put("status", status);
  491. upMap.put("bank", rpMap.get("channelType"));
  492. if (order.getPayId() == null) {
  493. upMap.put("payId", rpMap.get("orderNo"));
  494. }
  495. ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  496. if (status == 2) {
  497. upMap.put("pay", rpMap.get("totalMoney"));
  498. upMap.put("payTime", new Date());
  499. if (order.getTuiFee() != null) { //乐团报名
  500. applyInfo.setStatus(1);
  501. applyInfoService.update(applyInfo);
  502. }
  503. }
  504. if (status == 0) {
  505. //失败减去已收款金额
  506. Account account = accountService.get(Integer.parseInt(order.getUAccount()));
  507. BigDecimal HasRouting = account.getHasRouting().subtract(order.getAmount());
  508. account.setHasRouting(HasRouting);
  509. accountService.upByIdAndVersion(account);
  510. //减去报名人数
  511. if (order.getTuiFee() != null) {
  512. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getGroupId());
  513. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() - 1);
  514. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  515. }
  516. }
  517. orderService.updateByIdAndStatus(upMap);
  518. //推送mec
  519. if (status == 2) {
  520. if (order.getTuiFee() != null) { //乐团报名
  521. applyInfoService.userRegister(applyInfo.getPatriarchPhone(), order.getId()); //推送mec
  522. schoolService.sendPayMsg(applyInfo.getPatriarchPhone(), order.getAmount().toString());
  523. } else {
  524. Renewals renewals = renewalsService.getRenewalsByOrderId(order.getId());
  525. RenewBean renewBean = new RenewBean();
  526. // renewBean.setUserId(renewals.getUserId());
  527. // renewBean.setClassId(renewals.getClassId());
  528. // renewBean.setWay(renewals.getWay());
  529. // renewBean.setPay(renewals.getPay());
  530. // renewBean.setChargeMode(renewals.getChangeMode());
  531. // renewBean.setBuy(new BigDecimal(renewals.getBuy()));
  532. // renewBean.setPrice(renewals.getPrice());
  533. renewBean.setUserId(renewals.getUserId());
  534. renewBean.setType(101);
  535. renewBean.setIn(renewals.getPay());
  536. renewBean.setOut(new BigDecimal(0));
  537. renewBean.setWay(renewals.getWay());
  538. applyInfoService.pushRenew(renewBean);
  539. }
  540. }
  541. }
  542. @Transactional(rollbackFor = Exception.class)
  543. public void failOrders(ArrayList<String> orderNoList) throws Exception {
  544. if (orderNoList.size() == 0) {
  545. return;
  546. }
  547. Calendar beforeTime = Calendar.getInstance();
  548. beforeTime.add(Calendar.MINUTE, -15);// 5分钟之前的时间
  549. Date beforeDate = beforeTime.getTime();
  550. Map<String, Object> rqMap = new HashMap<>();
  551. rqMap.put("orderNoList", orderNoList);
  552. rqMap.put("beforeTime", beforeDate);
  553. List<Order> payingOrders = orderService.findPayingOrdersOver(rqMap);
  554. for (Order order : payingOrders) {
  555. HashMap<String, Object> upMap = new HashMap<>();
  556. upMap.put("id", order.getId());
  557. upMap.put("oldStatus", 1);
  558. upMap.put("status", 0);
  559. //失败减去已收款金额
  560. Account account = accountService.get(Integer.parseInt(order.getUAccount()));
  561. BigDecimal HasRouting = account.getHasRouting().subtract(order.getAmount());
  562. account.setHasRouting(HasRouting);
  563. accountService.upByIdAndVersion(account);
  564. //减去报名人数
  565. if (order.getTuiFee() != null) {
  566. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getGroupId());
  567. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() - 1);
  568. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  569. }
  570. orderService.updateByIdAndStatus(upMap);
  571. }
  572. }
  573. }