YqPayController.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487
  1. package com.ym.mec.collectfee.controller;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.ym.mec.collectfee.common.sms.SmsExample;
  5. import com.ym.mec.collectfee.common.web.BaseController;
  6. import com.ym.mec.collectfee.entity.*;
  7. import com.ym.mec.collectfee.service.*;
  8. import com.ym.mec.collectfee.utils.Constants;
  9. import com.ym.mec.collectfee.utils.GenerateNum;
  10. import com.ym.mec.collectfee.utils.ShortUrlUtil;
  11. import com.ym.mec.collectfee.utils.yqpay.*;
  12. import lombok.extern.slf4j.Slf4j;
  13. import org.apache.commons.io.IOUtils;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.core.io.ClassPathResource;
  16. import org.springframework.scheduling.annotation.EnableScheduling;
  17. import org.springframework.scheduling.annotation.Scheduled;
  18. import org.springframework.transaction.annotation.Transactional;
  19. import org.springframework.validation.annotation.Validated;
  20. import org.springframework.web.bind.annotation.ModelAttribute;
  21. import org.springframework.web.bind.annotation.PostMapping;
  22. import org.springframework.web.bind.annotation.RequestMapping;
  23. import org.springframework.web.bind.annotation.RestController;
  24. import sun.plugin2.util.NativeLibLoader;
  25. import java.io.InputStreamReader;
  26. import java.math.BigDecimal;
  27. import java.time.LocalDateTime;
  28. import java.util.*;
  29. //@Api("支付")
  30. @Slf4j
  31. @RestController
  32. @RequestMapping("yqpay")
  33. @EnableScheduling // 2.开启定时任务
  34. public class YqPayController extends BaseController {
  35. @Autowired
  36. private YqPayService yqPayService;
  37. @Autowired
  38. private YqQueryService yqQueryService;
  39. @Autowired
  40. private OrderService orderService;
  41. @Autowired
  42. private AccountService accountService;
  43. @Autowired
  44. private CourseGroupInfoService CourseGroupInfoService;
  45. @Autowired
  46. private ApplyInfoService applyInfoService;
  47. @Autowired
  48. private RenewalsService renewalsService;
  49. @Autowired
  50. private SchoolService schoolService;
  51. /**
  52. * 统一下单(乐团缴费)
  53. *
  54. * @return String
  55. * @throws Exception
  56. */
  57. // @ApiOperation(value = "提交支付", notes = "易乾支付统一下单")
  58. @PostMapping("/toPay")
  59. @Transactional
  60. public Object toPay(@ModelAttribute @Validated Order order) throws Exception {
  61. BigDecimal amount = new BigDecimal("0");
  62. School school = schoolService.get(order.getClassId());
  63. //计划招生人数有更新,更新
  64. orderService.getSchoolDetail(school.getSchoolId(), order.getClassId());
  65. //1、判断已报名人数
  66. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getCourseId());
  67. if (courseGroupInfo.getRegNum().compareTo(courseGroupInfo.getPlanNum()) >= 0) {
  68. return failed("乐团人数暂时已满,请稍后再试");
  69. }
  70. //课程组价格
  71. BigDecimal courseFee = courseGroupInfo.getFeeAmount();
  72. amount = amount.add(courseFee);
  73. //获取乐器的价格
  74. ClassPathResource classPathResource = new ClassPathResource("instruments.json"); //解析乐器数据
  75. BigDecimal instrumentPrice = new BigDecimal("0");//乐器价格
  76. String instrumentName = "";//乐器名称
  77. String instrumentId = order.getInstrument();
  78. String jsonString = IOUtils.toString(new InputStreamReader(classPathResource.getInputStream(), "UTF-8"));
  79. Instrument instrument = JSONObject.parseObject(jsonString, Instrument.class);
  80. if (order.getInstrument() != null && !order.getInstrument().isEmpty()) {
  81. instrumentPrice = new BigDecimal(instrument.getInstruments().get(instrumentId).get("referencePrice"));
  82. instrumentName = (String) instrument.getInstruments().get(instrumentId).get("index") + "-" +
  83. (String) instrument.getInstruments().get(instrumentId).get("name");
  84. }
  85. //2 版本为3.0( 26),不收乐器费用,收押金800放乐器费用
  86. if (courseGroupInfo.getFeeType().equals(26)) {
  87. instrumentPrice = new BigDecimal("800");
  88. }
  89. amount = amount.add(instrumentPrice);
  90. //辅件价格
  91. String adjunctIds = order.getAdjunct();
  92. BigDecimal adjunctPrice = new BigDecimal("0");//辅件价格
  93. String adjunctName = "";//辅件名称
  94. if (adjunctIds != null && !adjunctIds.isEmpty()) {
  95. String[] adjunctIdArr = adjunctIds.split(",");
  96. for (String adjunctId : adjunctIdArr) {
  97. adjunctPrice = adjunctPrice.add(new BigDecimal(instrument.getAuxiliaries().get(adjunctId).get("referencePrice")));
  98. adjunctName += (String) instrument.getAuxiliaries().get(adjunctId).get("name") + "|";
  99. }
  100. }
  101. amount = amount.add(adjunctPrice);
  102. ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  103. order.setPoName(school.getName());
  104. order.setVoicyPart(courseGroupInfo.getSubName());
  105. order.setGroupId(courseGroupInfo.getId());
  106. order.setAmount(amount);
  107. order.setRemark(instrumentName);
  108. order.setTuiFee(courseFee);
  109. order.setGoodsFee(instrumentPrice);
  110. order.setSdName(adjunctName + "教材|琴谱");
  111. order.setSdFee(adjunctPrice);
  112. order.setType(1);
  113. order.setUserName(applyInfo.getName());
  114. String orderNo = GenerateNum.getInstance().GenerateOrderNo(); //自己系统订单号
  115. order.setOrderNo(orderNo);
  116. order.setCreateTime(new Date()); //订单提交时间
  117. order.setStatus(1); //订单状态
  118. //获取分佣账户
  119. Integer branchId = 1001;//order.getBranchId();
  120. Account routingAccount = accountService.getRoutingAccount(branchId);
  121. order.setAccount(routingAccount.getSellerNo());
  122. order.setUAccount(routingAccount.getId().toString());
  123. //1、插入订单
  124. orderService.insert(order);
  125. //2、修改已报名人数
  126. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() + 1);
  127. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  128. //3、修改分佣账户已收金额
  129. BigDecimal HasRouting = routingAccount.getHasRouting().add(order.getAmount());
  130. routingAccount.setHasRouting(HasRouting);
  131. accountService.upByIdAndVersion(routingAccount);
  132. order.setAmount(new BigDecimal("2")); //测试账户设置金额
  133. Map rqMap = orderService.getPayMap(routingAccount, order, school); //获取支付map
  134. return succeed(rqMap);
  135. }
  136. /**
  137. * 续费支付
  138. *
  139. * @return String
  140. * @throws Exception
  141. */
  142. // @ApiOperation(value = "续费支付", notes = "续费支付")
  143. @PostMapping("/renewalsPay")
  144. public Object renewalsPay(@ModelAttribute @Validated Renewals renewals) throws Exception {
  145. MecUser mecUser = applyInfoService.findMecUser(renewals.getUserId());
  146. if (mecUser == null) {
  147. return failed("续费用户不存在");
  148. }
  149. renewals.setBranchId(mecUser.getBranchId());
  150. //课程组价格
  151. List<MecCourse> courses = applyInfoService.queryUserCourse(renewals.getUserId());//获取续费课程
  152. if (courses == null) {
  153. return failed("您没有续费的课程");
  154. }
  155. MecCourse mecCourse4json = JSON.parseObject(renewals.getCourses(), MecCourse.class);
  156. if (mecCourse4json == null) {
  157. return failed("请选择续费课程");
  158. }
  159. //classType 小课1 大课2
  160. Integer buyCount = mecCourse4json.getBuyCount();
  161. if (buyCount <= 0 || buyCount > 20) {
  162. return failed("购买课程次数不能小于1,大于20");
  163. }
  164. BigDecimal amount = new BigDecimal("0"); //课程总价
  165. String remark = "";
  166. List<MecCourse> pickCourses = new ArrayList<>();
  167. for (int i = 0; i < courses.size(); i++) {
  168. MecCourse course = courses.get(i);
  169. if (mecCourse4json.getCourseId().equals(course.getCourseId().intValue())) {
  170. BigDecimal price = course.getClassType().equals(1) ? course.getPrice().multiply(BigDecimal.valueOf(buyCount)) : course.getPrice().multiply(BigDecimal.valueOf(course.getBuyCount()));
  171. amount = amount.add(price);
  172. remark += course.getClassName();
  173. if (course.getClassType().equals(1)) {
  174. course.setBuyCount(buyCount);
  175. }
  176. pickCourses.add(course);
  177. }
  178. }
  179. if (pickCourses.size() == 0) {
  180. return failed("请选择续费课程");
  181. }
  182. String orderNo = GenerateNum.getInstance().GenerateOrderNo(); //自己系统订单号
  183. //获取分佣账户
  184. Integer branchId = 1001;//order.getBranchId();
  185. Account routingAccount = accountService.getRoutingAccount(branchId);
  186. Order order = renewalsService.addRenewalsOrder(renewals, amount, orderNo, pickCourses, routingAccount, remark);
  187. order.setAmount(new BigDecimal("2")); //测试账户设置金额
  188. Map rqMap = orderService.getPayMap(routingAccount, order, null); //获取支付map
  189. return succeed(rqMap);
  190. }
  191. /**
  192. * 交易查询
  193. *
  194. * @param merOrderNoList 用户订单号
  195. * @return
  196. * @throws Exception
  197. */
  198. //@PostMapping("/query")
  199. //@Scheduled(cron = "0/3 40 11 * * ?")
  200. public Object query(String merOrderNoList) throws Exception {
  201. String notifyUrl = ""; //回调地址
  202. Map<String, Object> resultMap = new LinkedHashMap<>();
  203. resultMap.put("merOrderNoList", merOrderNoList);
  204. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  205. return yqQueryService.orderQuery(requestMap);
  206. }
  207. /**
  208. * 用户信息(商户)查询
  209. *
  210. * @param sonMerNo 子商户号
  211. * @return
  212. * @throws Exception
  213. */
  214. @PostMapping("/queryaccount")
  215. public String queryAccount(String sonMerNo) throws Exception {
  216. String notifyUrl = ""; //回调地址
  217. Map<String, Object> resultMap = new LinkedHashMap<>();
  218. resultMap.put("merOrderNoList", sonMerNo);
  219. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  220. return yqQueryService.queryAccount(requestMap);
  221. }
  222. /**
  223. * 对账查询(定时任务每天对账)
  224. *
  225. * @return
  226. */
  227. public String queryBill() throws Exception {
  228. String notifyUrl = ""; //回调地址
  229. Map<String, Object> resultMap = new LinkedHashMap<>();
  230. resultMap.put("tradeDate", ""); //交易日期
  231. resultMap.put("payState", ""); //订单状态
  232. resultMap.put("tradeType", ""); //交易类型,不填为全部
  233. resultMap.put("channelType", ""); //通道类型,不填为全部
  234. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  235. return yqQueryService.billQuery(requestMap);
  236. }
  237. /**
  238. * 平台转账
  239. *
  240. * @return
  241. * @throws Exception
  242. */
  243. @PostMapping("/platformtransferacc")
  244. public String platformTransferAcc() throws Exception {
  245. String notifyUrl = ""; //回调地址
  246. Map<String, Object> resultMap = new LinkedHashMap<>();
  247. resultMap.put("payeeNo", ""); //收款方商户号
  248. resultMap.put("payeeName", ""); //收款方姓名
  249. resultMap.put("amount", ""); //金额
  250. resultMap.put("merOrderNo", ""); //商户订单号
  251. resultMap.put("remarks", ""); //备注
  252. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  253. return yqPayService.platformTransferAcc(requestMap);
  254. }
  255. /**
  256. * 提现短信
  257. *
  258. * @return
  259. * @throws Exception
  260. */
  261. @PostMapping("/sendsms")
  262. public Msg sendSms(@ModelAttribute Intfc intfc) throws Exception {
  263. String notifyUrl = ""; //回调地址
  264. String merMerOrderNo = GenerateNum.getInstance().GenerateOrderNo();
  265. Map<String, Object> resultMap = new LinkedHashMap<>();
  266. resultMap.put("wdMerNo", intfc.getWdMerNo()); //提现商户号
  267. resultMap.put("merMerOrderNo", merMerOrderNo); //商户订单号
  268. resultMap.put("amount", intfc.getAmount()); //提现金额
  269. resultMap.put("cardNo", intfc.getCardNo()); //提现银行卡号
  270. // resultMap.put("phone", intfc.getPhone()); //预留手机号(选填)
  271. // resultMap.put("cardType", intfc.getCardType()); //卡类型 0-个人银行卡,1-企业银行卡。(选填)
  272. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  273. return yqPayService.intfc(requestMap);
  274. }
  275. /**
  276. * 提现
  277. *
  278. * @return
  279. * @throws Exception
  280. */
  281. @PostMapping("/intfc")
  282. public Msg intfc(@ModelAttribute Intfc intfc) throws Exception {
  283. String notifyUrl = "http://47.99.212.176:9000/yqpay/notify"; //回调地址
  284. String merMerOrderNo = GenerateNum.getInstance().GenerateOrderNo();
  285. Map<String, Object> resultMap = new LinkedHashMap<>();
  286. resultMap.put("wdMerNo", intfc.getWdMerNo()); //提现商户号
  287. resultMap.put("merMerOrderNo", merMerOrderNo); //商户订单号
  288. resultMap.put("amount", intfc.getAmount()); //提现金额
  289. resultMap.put("cardNo", intfc.getCardNo()); //提现银行卡号
  290. // resultMap.put("phone", intfc.getPhone()); //预留手机号(选填)
  291. // resultMap.put("cardType", intfc.getCardType()); //卡类型 0-个人银行卡,1-企业银行卡。(选填)
  292. resultMap.put("seqNo", ""); //流水号(选填)
  293. resultMap.put("smsCode", ""); //验证码(选填)
  294. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  295. return yqPayService.intfc(requestMap);
  296. }
  297. /**
  298. * 易乾异步通知接口
  299. *
  300. * @param msg
  301. * @return String
  302. * @throws Exception
  303. */
  304. @PostMapping("/notify")
  305. public Msg notify(@ModelAttribute Msg msg) throws Exception {
  306. // log.info(msg.toString());K
  307. Map<String, Object> rqMap = new LinkedHashMap<String, Object>();
  308. rqMap.put("code", msg.getCode());
  309. rqMap.put("msg", msg.getMsg());
  310. rqMap.put("responseType", msg.getResponseType());
  311. rqMap.put("responseParameters", msg.getResponseParameters());
  312. rqMap.put("sign", msg.getSign());
  313. boolean rs = YqPayUtil.verify(rqMap);
  314. msg.setCode("");
  315. msg.setMsg("fail");
  316. Order order = null;
  317. NotifyMsg notifyMsg = null;
  318. if (rs) {
  319. Map<String, String> notifyMap = JSON.parseObject(msg.getResponseParameters(), Map.class);
  320. String merMerOrderNo = notifyMsg.getMerMerOrderNo(); //自己系统订单号
  321. order = orderService.getOrderByOrderNo(merMerOrderNo);
  322. }
  323. //支付中订单存在,更新状态
  324. if (order != null && msg.getResponseType().equals("1")) {
  325. //更新订单状态
  326. HashMap<String, Object> upMap = new HashMap<>();
  327. upMap.put("oldStatus", order.getStatus());
  328. int status = msg.getCode().equals("88") ? 2 : 0;
  329. upMap.put("status", status);
  330. upMap.put("bank", notifyMsg.getChannelType());//支付通道
  331. if (order.getOrderNo().isEmpty()) {
  332. upMap.put("payId", notifyMsg.getOrderNo());//更新易乾付订单号
  333. }
  334. if (status == 2) {
  335. upMap.put("pay", notifyMsg.getPayAmount());
  336. upMap.put("payTime", new Date());//付款时间
  337. }
  338. // orderService.updateByIdAndStatus(upMap);
  339. //ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  340. //applyInfoService.userRegister(applyInfo.getPatriarchPhone(), order.getId()); //推送mec
  341. msg.setCode("000000");
  342. msg.setMsg("success");
  343. }
  344. return msg;
  345. }
  346. @Scheduled(cron = "0/5 * * * * ?")
  347. //@RequestMapping("/getOrderStatus")
  348. public void getOrderStatus() throws Exception {
  349. System.err.println("执行静态定时任务时间: " + LocalDateTime.now());
  350. List<Order> payingOrders = orderService.findPayingOrders();
  351. String merOrderNos = ""; //
  352. for (int i = 0; i < payingOrders.size(); i++) {
  353. merOrderNos += payingOrders.get(i).getOrderNo() + ",";
  354. }
  355. if (merOrderNos.isEmpty()) {
  356. return;
  357. }
  358. merOrderNos = merOrderNos.substring(0, merOrderNos.length() - 1);
  359. String notifyUrl = ""; //回调地址
  360. Map<String, Object> resultMap = new LinkedHashMap<>();
  361. resultMap.put("merOrderNoList", merOrderNos);
  362. Map<String, Object> requestMap = new YqPayUtil(notifyUrl, resultMap).getRequestMap();
  363. Msg queryRs = yqQueryService.orderQuery(requestMap);
  364. if (queryRs.getCode().equals("88")) {
  365. //更新订单状态
  366. String[] statusArr = {"0", "1", "7"};
  367. String responseParameters = queryRs.getResponseParameters();
  368. List<Map<String, String>> responseList = JSON.parseObject(responseParameters, List.class);
  369. for (int i = 0; i < responseList.size(); i++) {
  370. Map<String, String> rpMap = responseList.get(i);
  371. if (Arrays.asList(statusArr).contains(rpMap.get("tradeState"))) {
  372. this.updateOrder(rpMap);
  373. }
  374. }
  375. }
  376. }
  377. @Transactional
  378. public void updateOrder(Map<String, String> rpMap) {
  379. int status = rpMap.get("tradeState").equals("1") ? 2 : 0;
  380. Order order = orderService.getOrderByOrderNo(rpMap.get("merOrderNo"));
  381. if (order == null) {
  382. return;
  383. }
  384. HashMap<String, Object> upMap = new HashMap<>();
  385. upMap.put("oldStatus", 1);
  386. upMap.put("status", status);
  387. upMap.put("bank", rpMap.get("channelType"));
  388. if (order.getPayId() == null) {
  389. upMap.put("payId", rpMap.get("orderNo"));
  390. }
  391. if (status == 2) {
  392. upMap.put("pay", rpMap.get("totalMoney"));
  393. upMap.put("payTime", new Date());
  394. //推送mec
  395. if (order.getTuiFee() != null) { //乐团报名
  396. ApplyInfo applyInfo = applyInfoService.get(order.getUserId());
  397. applyInfo.setStatus(1);
  398. applyInfoService.update(applyInfo);
  399. applyInfoService.userRegister(applyInfo.getPatriarchPhone(), order.getId()); //推送mec
  400. schoolService.sendPayMsg(applyInfo.getPatriarchPhone(), order.getAmount().toString());
  401. } else {
  402. Renewals renewals = renewalsService.getRenewalsByOrderId(order.getId());
  403. RenewBean renewBean = new RenewBean();
  404. renewBean.setUserId(renewals.getUserId());
  405. renewBean.setClassId(renewals.getClassId());
  406. renewBean.setWay(renewals.getWay());
  407. renewBean.setPay(renewals.getPay());
  408. renewBean.setChargeMode(renewals.getChangeMode());
  409. renewBean.setBuy(new BigDecimal(renewals.getBuy()));
  410. renewBean.setPrice(renewals.getPrice());
  411. applyInfoService.pushRenew(renewBean);
  412. }
  413. }
  414. if (status == 0) {
  415. //失败减去已收款金额
  416. Account account = accountService.getAccountByBranchId(Integer.parseInt(order.getUAccount()));
  417. BigDecimal HasRouting = account.getHasRouting().subtract(order.getAmount());
  418. account.setHasRouting(HasRouting);
  419. accountService.upByIdAndVersion(account);
  420. //减去报名人数
  421. if (order.getTuiFee() != null) {
  422. CourseGroupInfo courseGroupInfo = CourseGroupInfoService.get(order.getGroupId());
  423. courseGroupInfo.setRegNum(courseGroupInfo.getRegNum() - 1);
  424. CourseGroupInfoService.upByIdAndVersion(courseGroupInfo);
  425. }
  426. }
  427. orderService.updateByIdAndStatus(upMap);
  428. }
  429. }