OrderController.java 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829
  1. package com.kmall.admin.controller;
  2. import com.kmall.admin.dto.OrderExpressDto;
  3. import com.kmall.admin.entity.*;
  4. import com.kmall.common.constant.JxlsXmlTemplateName;
  5. import com.kmall.common.utils.excel.ExcelUtil;
  6. import com.kmall.manager.manager.wechat.WechatUtil;
  7. import com.kmall.manager.manager.wechat.WechatGlobalUtil;
  8. import com.kmall.manager.manager.wechat.wxglobal.dto.WechatGlobalRefundApiResult;
  9. import com.kmall.admin.service.*;
  10. import com.kmall.admin.service.OrderExceptionRecordService;
  11. import com.kmall.admin.service.OrderProcessRecordService;
  12. import com.kmall.admin.service.OrderService;
  13. import com.kmall.admin.utils.ParamUtils;
  14. import com.kmall.admin.utils.ShiroUtils;
  15. import com.kmall.common.constant.Dict;
  16. import com.kmall.admin.fromcomm.entity.SysUserEntity;
  17. import com.kmall.common.utils.*;
  18. import com.kmall.common.utils.excel.ExcelExport;
  19. import com.kmall.manager.manager.pingan.PinganUtil;
  20. import com.kmall.manager.manager.pingan.dto.PinganResponseDto;
  21. import com.kmall.common.utils.print.ticket.item.Ticket;
  22. import com.kmall.common.utils.wechat.WechatMicropayApiResult;
  23. import com.kmall.common.utils.wechat.WechatRefundApiResult;
  24. import com.kmall.common.utils.wechat.WechatReverseApiResult;
  25. import net.sf.json.JSONObject;
  26. import org.apache.commons.lang3.StringUtils;
  27. import org.apache.commons.logging.Log;
  28. import org.apache.commons.logging.LogFactory;
  29. import org.apache.shiro.authz.annotation.RequiresPermissions;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.web.bind.annotation.*;
  32. import org.springframework.web.multipart.MultipartFile;
  33. import javax.servlet.http.HttpServletRequest;
  34. import javax.servlet.http.HttpServletResponse;
  35. import java.math.BigDecimal;
  36. import java.text.ParseException;
  37. import java.text.SimpleDateFormat;
  38. import java.util.*;
  39. /**
  40. * @author Scott
  41. * @email
  42. * @date 2017-08-13 10:41:09
  43. */
  44. @RestController
  45. @RequestMapping("order")
  46. public class OrderController {
  47. private Log logger = LogFactory.getLog(OrderController.class);
  48. @Autowired
  49. private OrderService orderService;
  50. @Autowired
  51. private OrderProcessRecordService orderProcessRecordService;
  52. @Autowired
  53. private OrderRefundService orderRefundService;
  54. @Autowired
  55. private OrderExceptionRecordService orderExceptionRecordService;
  56. @Autowired
  57. private StoreService storeService;
  58. @Autowired
  59. private OrderWXPayRecordService orderWXPayRecordService;
  60. @Autowired
  61. private PinganResponseService pinganResponseService;
  62. @Autowired
  63. private ExcelUtil excelUtil;
  64. @Autowired
  65. private ShippingService shippingService;
  66. /**
  67. * 列表
  68. */
  69. @RequestMapping("/list")
  70. @RequiresPermissions("order:list")
  71. public R list(@RequestParam Map<String, Object> params) {
  72. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  73. params = ParamUtils.setTimeMap(params);
  74. //查询列表数据
  75. Query query = new Query(params);
  76. query.put("isOnfiilineOrder", Dict.isOnfflineOrder.item_0.getItem());
  77. List<OrderEntity> orderList = orderService.queryList(query);
  78. int total = orderService.queryTotal(query);
  79. PageUtils pageUtil = new PageUtils(orderList, total, query.getLimit(), query.getPage());
  80. return R.ok().put("page", pageUtil);
  81. }
  82. /**
  83. * 信息
  84. */
  85. @RequestMapping("/info/{id}")
  86. @RequiresPermissions("order:info")
  87. public R info(@PathVariable("id") Long id) {
  88. OrderEntity order = orderService.queryObject(id);
  89. return R.ok().put("order", order);
  90. }
  91. /**
  92. * 信息
  93. */
  94. @RequestMapping("/infos/{id}")
  95. @RequiresPermissions("order:infos")
  96. public R infos(@PathVariable("id") Long id) {
  97. OrderEntity order = orderService.queryInfos(id);
  98. return R.ok().put("order", order);
  99. }
  100. /**
  101. * 保存
  102. */
  103. @RequestMapping("/save")
  104. @RequiresPermissions("order:save")
  105. public R save(@RequestBody OrderEntity order) {
  106. orderService.save(order);
  107. return R.ok();
  108. }
  109. /**
  110. * 修改
  111. */
  112. @RequestMapping("/update")
  113. @RequiresPermissions("order:update")
  114. public R update(@RequestBody OrderEntity order) {
  115. orderService.update(order);
  116. return R.ok();
  117. }
  118. /**
  119. * 删除
  120. */
  121. @RequestMapping("/delete")
  122. @RequiresPermissions("order:delete")
  123. public R delete(@RequestBody Long[] ids) {
  124. orderService.deleteBatch(ids);
  125. return R.ok();
  126. }
  127. /**
  128. * 查看所有列表
  129. */
  130. @RequestMapping("/queryAll")
  131. public R queryAll(@RequestParam Map<String, Object> params) {
  132. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  133. List<OrderEntity> list = orderService.queryList(params);
  134. return R.ok().put("list", list);
  135. }
  136. /**
  137. * 总计
  138. */
  139. @RequestMapping("/queryTotal")
  140. public R queryTotal(@RequestParam Map<String, Object> params) {
  141. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  142. int sum = orderService.queryTotal(params);
  143. return R.ok().put("sum", sum);
  144. }
  145. /**
  146. * 确定收货
  147. *
  148. * @param id
  149. * @return
  150. */
  151. @RequestMapping("/confirm")
  152. @RequiresPermissions("order:confirm")
  153. public R confirm(@RequestBody Long id) {
  154. orderService.confirm(id);
  155. return R.ok();
  156. }
  157. /**
  158. * 发货
  159. *
  160. * @param order
  161. * @return
  162. */
  163. @RequestMapping("/sendGoods")
  164. @RequiresPermissions("order:sendGoods")
  165. public R sendGoods(@RequestBody OrderEntity order) {
  166. orderService.sendGoods(order);
  167. return R.ok();
  168. }
  169. /**
  170. * 跟踪快递轨迹
  171. *
  172. * @param id
  173. * @return
  174. */
  175. @RequestMapping("/getLogistics/{id}")
  176. @RequiresPermissions("order:getLogistics")
  177. public R getLogistics(@PathVariable("id") Long id) {
  178. Map result = orderService.getLogistics(id);
  179. return R.ok().put("result", result);
  180. }
  181. /**
  182. * 获取订单清关信息
  183. *
  184. * @param orderSn
  185. * @return
  186. */
  187. @RequestMapping("/getProcess/{orderSn}")
  188. @RequiresPermissions("order:getProcess")
  189. public R getProcess(@PathVariable("orderSn") String orderSn) {
  190. OrderProcessRecordEntity orderProcessRecordEntity = orderProcessRecordService.queryObjectByOrderSn(orderSn);
  191. if (orderProcessRecordEntity != null) {
  192. if (orderProcessRecordEntity.getShipmentStartTime() != null) {
  193. orderProcessRecordEntity.setShipmentStartTimeStr(
  194. DateUtils.format(orderProcessRecordEntity.getShipmentStartTime(), DateUtils.DATE_TIME_PATTERN));
  195. }
  196. if (orderProcessRecordEntity.getShipmentSuccTime() != null) {
  197. orderProcessRecordEntity.setShipmentSuccTimeStr(
  198. DateUtils.format(orderProcessRecordEntity.getShipmentSuccTime(), DateUtils.DATE_TIME_PATTERN));
  199. }
  200. if (orderProcessRecordEntity.getCustomsStartTime() != null) {
  201. orderProcessRecordEntity.setCustomsStartTimeStr(
  202. DateUtils.format(orderProcessRecordEntity.getCustomsStartTime(), DateUtils.DATE_TIME_PATTERN));
  203. }
  204. if (orderProcessRecordEntity.getCustomsSuccTime() != null) {
  205. orderProcessRecordEntity.setCustomsSuccTimeStr(
  206. DateUtils.format(orderProcessRecordEntity.getCustomsSuccTime(), DateUtils.DATE_TIME_PATTERN));
  207. }
  208. if (orderProcessRecordEntity.getWaybillStartTime() != null) {
  209. orderProcessRecordEntity.setWaybillStartTimeStr(
  210. DateUtils.format(orderProcessRecordEntity.getWaybillStartTime(), DateUtils.DATE_TIME_PATTERN));
  211. }
  212. if (orderProcessRecordEntity.getWaybillSuccTime() != null) {
  213. orderProcessRecordEntity.setWaybillSuccTimeStr(
  214. DateUtils.format(orderProcessRecordEntity.getWaybillSuccTime(), DateUtils.DATE_TIME_PATTERN));
  215. }
  216. if (orderProcessRecordEntity.getEleOrderStartTime() != null) {
  217. orderProcessRecordEntity.setEleOrderStartTimeStr(
  218. DateUtils.format(orderProcessRecordEntity.getEleOrderStartTime(), DateUtils.DATE_TIME_PATTERN));
  219. }
  220. if (orderProcessRecordEntity.getEleOrderSuccTime() != null) {
  221. orderProcessRecordEntity.setEleOrderSuccTimeStr(
  222. DateUtils.format(orderProcessRecordEntity.getEleOrderSuccTime(), DateUtils.DATE_TIME_PATTERN));
  223. }
  224. if (orderProcessRecordEntity.getAddOrderStartTime() != null) {
  225. orderProcessRecordEntity.setAddOrderStartTimeStr(
  226. DateUtils.format(orderProcessRecordEntity.getAddOrderStartTime(), DateUtils.DATE_TIME_PATTERN));
  227. }
  228. if (orderProcessRecordEntity.getAddOrderSuccTime() != null) {
  229. orderProcessRecordEntity.setAddOrderSuccTimeStr(
  230. DateUtils.format(orderProcessRecordEntity.getAddOrderSuccTime(), DateUtils.DATE_TIME_PATTERN));
  231. }
  232. if (orderProcessRecordEntity.getPaySuccTime() != null) {
  233. orderProcessRecordEntity.setPaySuccTimeStr(
  234. DateUtils.format(orderProcessRecordEntity.getPaySuccTime(), DateUtils.DATE_TIME_PATTERN));
  235. }
  236. if (orderProcessRecordEntity.getPayStartTime() != null) {
  237. orderProcessRecordEntity.setPayStartTimeStr(
  238. DateUtils.format(orderProcessRecordEntity.getPayStartTime(), DateUtils.DATE_TIME_PATTERN));
  239. }
  240. if (orderProcessRecordEntity.getPaymentStartTime() != null) {
  241. orderProcessRecordEntity.setPaymentStartTimeStr(
  242. DateUtils.format(orderProcessRecordEntity.getPaymentStartTime(), DateUtils.DATE_TIME_PATTERN));
  243. }
  244. if (orderProcessRecordEntity.getPaymentSuccTime() != null) {
  245. orderProcessRecordEntity.setPaymentSuccTimeStr(
  246. DateUtils.format(orderProcessRecordEntity.getPaymentSuccTime(), DateUtils.DATE_TIME_PATTERN));
  247. }
  248. }
  249. return R.ok().put("orderProcessRecordEntity", orderProcessRecordEntity);
  250. }
  251. /**
  252. * 打印小票
  253. *
  254. * @param id
  255. * @return
  256. */
  257. @RequestMapping("/printMsg")
  258. public R printMsg(@RequestBody Long id) {
  259. Ticket ticket = orderService.printMsg(id);
  260. return R.ok().put("ticket", ticket);
  261. }
  262. /**
  263. * 订单取消请求
  264. */
  265. @RequiresPermissions(value = {"order:refund"})
  266. @RequestMapping(value = "cancel", method = RequestMethod.POST)
  267. public Object cancel(Long orderId) {
  268. OrderEntity orderInfo = orderService.queryObject(orderId);
  269. if (null == orderInfo) {
  270. return R.error("订单不存在");
  271. }
  272. if (orderInfo.getOrderStatus() != 0) {
  273. return R.error("订单状态不支持取消");
  274. }
  275. orderService.cancelOrder(orderInfo);
  276. return R.ok();
  277. }
  278. /**
  279. * 订单退款请求
  280. */
  281. @RequiresPermissions(value = {"order:refund"})
  282. @RequestMapping(value = "refund", method = RequestMethod.POST)
  283. public Object refund(Long orderId, String refundId, BigDecimal refundMoney) {
  284. OrderEntity orderInfo = orderService.queryObject(orderId);
  285. if (null == orderInfo) {
  286. return R.error("订单不存在");
  287. }
  288. if (orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_401.getItem()) ||
  289. orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_402.getItem())) {
  290. return R.error("订单已退款");
  291. }
  292. Double totalActualPrice = orderService.getTotalActualPrice(orderInfo.getMerchOrderSn());
  293. if (totalActualPrice == null) {
  294. totalActualPrice = 0d;
  295. }
  296. OrderProcessRecordEntity processRecordEntity = orderProcessRecordService.queryObjectByOrderSn(orderInfo.getOrderSn());
  297. if(org.apache.commons.lang.StringUtils.isNotEmpty(processRecordEntity.getIsCustomsSend())) {
  298. if (processRecordEntity.getIsCustomsSend().equalsIgnoreCase("2")) {
  299. return R.error("订单正在清关中,不能退款");
  300. }
  301. if (processRecordEntity.getIsCustomsSend().equalsIgnoreCase("1")) {
  302. return R.error("订单已清关完成,不能退款");
  303. }
  304. }
  305. String refundResult = "";
  306. if (orderInfo.getOrderStatus() != Integer.parseInt(Dict.orderStatus.item_0.getItem())) {
  307. if (orderInfo.getPayFlag().equalsIgnoreCase(Dict.payFlag.item_wxglobalpay.getItem())) {
  308. refundResult = wxGlobalRefund(orderInfo, totalActualPrice);
  309. if (StringUtils.isNotBlank(refundResult)) {
  310. return R.error(refundResult);
  311. }
  312. } else if (orderInfo.getPayFlag().equalsIgnoreCase(Dict.payFlag.item_pingan.getItem())) {
  313. refundResult = pinganRefund(orderInfo, refundId);
  314. if (StringUtils.isNotBlank(refundResult)) {
  315. return R.error(refundResult);
  316. }
  317. } else{
  318. refundResult = wxRefund(orderInfo,totalActualPrice);
  319. if(StringUtils.isNotBlank(refundResult)){
  320. return R.error(refundResult);
  321. }
  322. }
  323. }
  324. return R.ok("退款成功");
  325. }
  326. /**
  327. * 平安申请退款
  328. * @param orderInfo
  329. * @return
  330. */
  331. private String pinganRefund(OrderEntity orderInfo, String refundId){
  332. Integer refundAmount = orderInfo.getActualPrice().multiply(new BigDecimal(100)).intValue();
  333. PinganResponseDto responseDto = PinganUtil.pinganPayRefund(orderInfo.getMerchOrderSn(), refundId, refundAmount, null);
  334. if (!Objects.isNull(responseDto)) {
  335. responseDto.setOutNo(orderInfo.getMerchOrderSn());
  336. responseDto.setCreateTime(new Date());
  337. pinganResponseService.save(responseDto);
  338. if ("0".equals(responseDto.getErrcode())) {
  339. JSONObject tradeResult = JSONObject.fromObject(responseDto.getDatajson());
  340. if (Dict.pinganRefundStatus.item_1.getItem().equals(tradeResult.getString("status"))) {
  341. orderService.pinganRefund(orderInfo, tradeResult, refundId);
  342. } else {
  343. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  344. OrderRefundEntity orderRefund = new OrderRefundEntity();
  345. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  346. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  347. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  348. SysUserEntity user = ShiroUtils.getUserEntity();
  349. orderRefund.setModerSn(user.getUsername());
  350. orderRefund.setModTime(new Date());
  351. orderRefund.setOutRefundNo(tradeResult.getString("ord_no"));
  352. if (mallOrderRefund != null) {
  353. orderRefund.setId(mallOrderRefund.getId());
  354. orderRefundService.update(orderRefund);//退款记录
  355. }
  356. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  357. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  358. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  359. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  360. mallOrderExceptionRecord.setExceptionContent("退款失败");
  361. mallOrderExceptionRecord.setCreateTime(new Date());
  362. orderExceptionRecordService.save(mallOrderExceptionRecord);
  363. return "发起平安支付退款失败!";
  364. }
  365. } else {
  366. return responseDto.getMsg();
  367. }
  368. }
  369. return "";
  370. }
  371. /**
  372. * 微信申请退款
  373. * @param orderInfo
  374. * @param totalActualPrice
  375. * @return
  376. */
  377. private String wxRefund(OrderEntity orderInfo,Double totalActualPrice){
  378. WechatRefundApiResult result = WechatUtil.wxRefund(orderInfo.getMerchOrderSn().toString(), totalActualPrice,
  379. orderInfo.getActualPrice().doubleValue());
  380. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  381. orderService.refund(orderInfo, result);
  382. } else {
  383. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  384. OrderRefundEntity orderRefund = new OrderRefundEntity();
  385. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  386. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  387. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  388. SysUserEntity user = ShiroUtils.getUserEntity();
  389. orderRefund.setModerSn(user.getUsername());
  390. orderRefund.setModTime(new Date());
  391. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  392. if (mallOrderRefund != null) {
  393. orderRefund.setId(mallOrderRefund.getId());
  394. orderRefundService.update(orderRefund);//退款记录
  395. }
  396. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  397. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  398. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  399. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  400. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  401. mallOrderExceptionRecord.setCreateTime(new Date());
  402. orderExceptionRecordService.save(mallOrderExceptionRecord);
  403. return result.getErr_code_des();
  404. }
  405. return "";
  406. }
  407. /**
  408. * 微信国际申请退款
  409. * @param orderInfo
  410. * @param totalActualPrice
  411. * @return
  412. */
  413. private String wxGlobalRefund(OrderEntity orderInfo,Double totalActualPrice){
  414. WechatGlobalRefundApiResult result = WechatGlobalUtil.wxRefund(orderInfo.getMerchOrderSn().toString(), totalActualPrice,
  415. orderInfo.getActualPrice().doubleValue());
  416. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  417. orderService.globalRefund(orderInfo, result);
  418. } else {
  419. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  420. OrderRefundEntity orderRefund = new OrderRefundEntity();
  421. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  422. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  423. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  424. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  425. orderRefund.setModTime(new Date());
  426. if (mallOrderRefund != null) {
  427. orderRefund.setId(mallOrderRefund.getId());
  428. orderRefundService.update(orderRefund);//退款记录
  429. }
  430. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  431. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  432. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  433. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  434. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  435. mallOrderExceptionRecord.setCreateTime(new Date());
  436. orderExceptionRecordService.save(mallOrderExceptionRecord);
  437. return result.getErr_code_des();
  438. }
  439. return "";
  440. }
  441. /**
  442. * 订单退款请求
  443. */
  444. @RequiresPermissions(value = {"order:offilineRefund"})
  445. @RequestMapping(value = "offilineRefund", method = RequestMethod.POST)
  446. public Object offilineRefund(Long orderId) {
  447. OrderEntity orderInfo = orderService.queryObject(orderId);
  448. if (null == orderInfo) {
  449. return R.error("订单不存在");
  450. }
  451. if (orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_401.getItem()) ||
  452. orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_402.getItem())) {
  453. return R.error("订单已退款");
  454. }
  455. if (orderInfo.getOrderStatus() != Integer.parseInt(Dict.orderStatus.item_0.getItem())) {
  456. if (Dict.payFlag.item_cash.getItem().equals(orderInfo.getPayFlag())) {
  457. //现金支付,直接修改订单状态
  458. orderService.refund(orderInfo, null);
  459. } else if (Dict.payFlag.item_weixin.getItem().equals(orderInfo.getPayFlag())) {
  460. //微信线下扫码支付
  461. WechatRefundApiResult result = WechatUtil
  462. .wxRefund(orderInfo.getOrderSnWx(), orderInfo.getActualPrice().doubleValue(),
  463. orderInfo.getActualPrice().doubleValue());
  464. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  465. orderService.refund(orderInfo, result);
  466. } else {
  467. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  468. OrderRefundEntity orderRefund = new OrderRefundEntity();
  469. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  470. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  471. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  472. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  473. SysUserEntity user = ShiroUtils.getUserEntity();
  474. orderRefund.setModerSn(user.getUsername());
  475. orderRefund.setModTime(new Date());
  476. if (mallOrderRefund != null) {
  477. orderRefund.setId(mallOrderRefund.getId());
  478. orderRefundService.update(orderRefund);//退款记录
  479. }
  480. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  481. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  482. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  483. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  484. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  485. mallOrderExceptionRecord.setCreateTime(new Date());
  486. orderExceptionRecordService.save(mallOrderExceptionRecord);
  487. return R.error(result.getErr_code_des());
  488. }
  489. }
  490. }
  491. return R.ok("退款成功");
  492. }
  493. /**
  494. * 获取首页展示信息--会员购买率相关
  495. *
  496. * @param params
  497. * @return
  498. */
  499. @RequestMapping("/getUserOrderInfo")
  500. public R getUserOrderInfo(@RequestParam Map<String, Object> params) {
  501. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  502. int result = orderService.getUserOrderInfo(params);
  503. return R.ok().put("result", result);
  504. }
  505. @RequiresPermissions(value = {"order:orderSubmit"})
  506. @RequestMapping(value = "orderSubmit", method = RequestMethod.POST)
  507. @ResponseBody
  508. public R orderSubmit(@RequestBody List<OfflineCartEntity> offlineCartEntityList) {
  509. Map resultObj = null;
  510. try {
  511. SysUserEntity user = ShiroUtils.getUserEntity();
  512. resultObj = orderService.orderSubmit(offlineCartEntityList, user);
  513. if (((Integer) resultObj.get("errno")) != 0) {
  514. return R.error((String) resultObj.get("errmsg"));
  515. }
  516. } catch (Exception e) {
  517. e.printStackTrace();
  518. }
  519. return R.ok("订单提交成功");
  520. }
  521. /**
  522. * 确认付款
  523. *
  524. * @param id
  525. * @return
  526. */
  527. @RequestMapping("/confirmPay")
  528. @RequiresPermissions("order:confirmPay")
  529. public R confirmPay(@RequestBody Long id) {
  530. orderService.confirmPay(id, Dict.payFlag.item_cash.getItem(), null);
  531. return R.ok();
  532. }
  533. @RequestMapping("/offilineOrderList")
  534. @RequiresPermissions("order:offilineOrderList")
  535. public R offilineOrderList(@RequestParam Map<String, Object> params) {
  536. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  537. //查询列表数据
  538. Query query = new Query(params);
  539. query.put("isOnfiilineOrder", Dict.isOnfflineOrder.item_1.getItem());
  540. List<OrderEntity> orderList = orderService.queryOffilineOrderList(query);
  541. int total = orderService.queryTotal(query);
  542. PageUtils pageUtil = new PageUtils(orderList, total, query.getLimit(), query.getPage());
  543. return R.ok().put("page", pageUtil);
  544. }
  545. @RequestMapping("/offlineInfos/{id}")
  546. @RequiresPermissions("order:offlineInfos")
  547. public R queryObjectBySysUser(@PathVariable("id") Long id) {
  548. OrderEntity order = orderService.queryObjectBySysUser(id);
  549. List<OrderWXPayRecordEntity> payRecords = orderWXPayRecordService.getRecordsByOutTradeNo(order.getOrderSn());
  550. order.setPayRecordList(payRecords);
  551. return R.ok().put("order", order);
  552. }
  553. @RequestMapping("/wxMicropayPay")
  554. @RequiresPermissions("order:wxMicropayPay")
  555. public R wxMicropayPay(Long id, String auth_code) {
  556. R r = null;
  557. SysUserEntity user = ShiroUtils.getUserEntity();
  558. if (user == null) {
  559. throw new RRException("用户登录超时,请重新登录");
  560. }
  561. if (!user.getRoleType().equalsIgnoreCase("2")) {
  562. throw new RRException("该操作只允许店员账户操作");
  563. }
  564. OrderEntity orderEntity = orderService.queryObject(id);
  565. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_201.getItem())) {
  566. throw new RRException("此订单已付款!");
  567. }
  568. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_301.getItem())) {
  569. throw new RRException("此订单已完成!");
  570. }
  571. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_101.getItem())) {
  572. throw new RRException("此订单已取消!");
  573. }
  574. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_102.getItem())) {
  575. throw new RRException("此订单已删除!");
  576. }
  577. //保存支付记录
  578. OrderWXPayRecordEntity orderWXPayRecordCurrent = orderWXPayRecordService.saveRecord(orderEntity);
  579. StoreEntity store = storeService.queryObject(orderEntity.getStoreId());
  580. WechatMicropayApiResult wechatMicropayApiResult = WechatUtil
  581. .wxMicropay(store.getMerchName() + "-" + store.getStoreName(), orderEntity.getOrderBizType(), null,
  582. orderWXPayRecordCurrent.getOutTradeNoWX(), orderEntity.getActualPrice().doubleValue(),
  583. "127.0.0.1", auth_code);
  584. orderWXPayRecordService.updateRecord(orderWXPayRecordCurrent.getId(), wechatMicropayApiResult);
  585. //当支付成功时,修改订单,并把其他支付记录撤销
  586. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  587. //查询当前订单所有的支付记录
  588. List<OrderWXPayRecordEntity> orderWXPayRecordEntitys =
  589. orderWXPayRecordService.getRecordsByOutTradeNo(orderEntity.getOrderSn());
  590. for (OrderWXPayRecordEntity orderWXPayRecordTemp : orderWXPayRecordEntitys) {
  591. //查询出来的记录排除当前已支付成功的记录,对其他记录交易状态为未撤销,未关闭的订单,调用撤销订单
  592. if (orderWXPayRecordTemp.getId() != orderWXPayRecordCurrent.getId() &&
  593. (!WechatUtil.WXTradeState.REVOKED.getCode().equals(orderWXPayRecordTemp.getTradeState()) ||
  594. !WechatUtil.WXTradeState.CLOSED.getCode().equals(orderWXPayRecordTemp.getTradeState()))) {
  595. WechatReverseApiResult wechatReverseApiResult =
  596. WechatUtil.wxReverse(orderWXPayRecordTemp.getOutTradeNoWX());
  597. //撤销订单成功
  598. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getReturn_code()) &&
  599. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getResult_code())) {
  600. //调用订单查询接口
  601. WechatRefundApiResult wechatRefundApiResult =
  602. WechatUtil.wxOrderQuery(orderWXPayRecordTemp.getOutTradeNoWX());
  603. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getReturn_code()) &&
  604. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getResult_code())) {
  605. // 修改订单支付记录
  606. orderWXPayRecordService
  607. .updateWXPayRecordTradeState(orderWXPayRecordTemp.getId(), wechatRefundApiResult);
  608. }
  609. }
  610. }
  611. }
  612. orderService.confirmPay(id, Dict.payFlag.item_weixin.getItem(), orderWXPayRecordCurrent.getOutTradeNoWX());
  613. r = R.ok();
  614. //用户支付中
  615. } else if (WechatUtil.WXTradeState.USERPAYING.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  616. r = R.error(WechatUtil.WXTradeState.USERPAYING.getCodeZn() + ",稍等片刻后请刷新页面重新查看订单状态");
  617. //用户支付失败
  618. } else if (WechatUtil.WXTradeState.PAYERROR.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  619. WechatReverseApiResult wechatReverseApiResult =
  620. WechatUtil.wxReverse(orderWXPayRecordCurrent.getOutTradeNoWX());
  621. //撤销订单成功
  622. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getReturn_code()) &&
  623. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getResult_code())) {
  624. //调用订单查询接口
  625. WechatRefundApiResult wechatRefundApiResult =
  626. WechatUtil.wxOrderQuery(orderWXPayRecordCurrent.getOutTradeNoWX());
  627. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getReturn_code()) &&
  628. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getResult_code())) {
  629. // 修改订单支付记录
  630. orderWXPayRecordService
  631. .updateWXPayRecordTradeState(orderWXPayRecordCurrent.getId(), wechatRefundApiResult);
  632. }
  633. r = R.error(orderWXPayRecordCurrent.getErrCodeDes());
  634. } else {
  635. r = R.error(wechatReverseApiResult.getErr_code_des());
  636. }
  637. }
  638. return r;
  639. }
  640. /**
  641. * 订单导出请求
  642. */
  643. @RequiresPermissions(value = {"order:export"})
  644. @RequestMapping(value = "export")
  645. public Object export(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  646. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  647. params = ParamUtils.setTimeMap(params);
  648. //查询列表数据
  649. params.put("isOnfiilineOrder", Dict.isOnfflineOrder.item_0.getItem());
  650. List<OrderEntity> orderList = orderService.queryExportList(params);
  651. ExcelExport ee = new ExcelExport("订单信息");
  652. String[] header = new String[]{"订单编号","商户订单编号", "所属门店", "供应商", "供应商第三方商户代码", "订单状态", "SKU", "商品名称", "数量", "销售价", "实际支付金额", "保税模式", "快递公司名称", "快递单编号", "海关清单编号", "收货人姓名", "收件人手机", "收件人省份", "收件人城市", "收件人区县", "收件人地址", "下单时间", "支付流水号","身份证号"
  653. ,"原产国","规格型号","品牌","单位","毛重(kg)","净重"};
  654. List<Map<String, Object>> list = new ArrayList<>();
  655. if (orderList != null && orderList.size() != 0) {
  656. for (OrderEntity orderEntity : orderList) {
  657. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  658. Integer orderStatus = orderEntity.getOrderStatus();
  659. String orderBizType = orderEntity.getOrderBizType();
  660. map.put("OrderSn", orderEntity.getOrderSn());
  661. map.put("MerchOrderSn", orderEntity.getMerchOrderSn());
  662. map.put("StoreName", orderEntity.getStoreName());
  663. map.put("SupplierThirdPartyMerchName", orderEntity.getSupplierThirdPartyMerchName());
  664. map.put("SupplierThirdPartyMerchCode", orderEntity.getSupplierThirdPartyMerchCode());
  665. map.put("OrderStatus", StringUtils.isEmpty(orderStatus.toString())? "":Dict.orderStatus.valueOf("item_"+ orderStatus).getItemName());
  666. map.put("SKU", orderEntity.getSku());
  667. map.put("GoodsName", orderEntity.getGoodsName());
  668. map.put("Number", orderEntity.getNumber());
  669. map.put("RetailPrice", orderEntity.getRetailPrice());
  670. map.put("ActualPrice", orderEntity.getActualPrice());
  671. map.put("OrderBizType", StringUtils.isEmpty(orderBizType)? "":Dict.orderBizType.valueOf("item_"+orderBizType).getItemName());
  672. map.put("ShippingName", orderEntity.getShippingName());
  673. map.put("ShippingNo", orderEntity.getShippingNo());
  674. map.put("InvtNo", orderEntity.getOrderProcessRecord()==null?"":orderEntity.getOrderProcessRecord().getInvtNo());
  675. map.put("Consignee", orderEntity.getConsignee());
  676. map.put("Mobile", orderEntity.getMobile());
  677. map.put("Province", orderEntity.getProvince());
  678. map.put("City", orderEntity.getCity());
  679. map.put("District", orderEntity.getDistrict());
  680. map.put("Address", orderEntity.getAddress());
  681. map.put("OrderStartTime", orderEntity.getOrderProcessRecord()==null?"":DateUtils.format(orderEntity.getOrderProcessRecord().getAddOrderStartTime(),"yyyy-MM-dd HH:mm:ss"));
  682. map.put("PayId", orderEntity.getPayTransactionId());
  683. map.put("IdNo", orderEntity.getIdNo());
  684. map.put("OriCntCode", orderEntity.getOriCntCode());
  685. map.put("CiqProdModel", orderEntity.getCiqProdModel());
  686. map.put("Brand", orderEntity.getBrand());
  687. map.put("UnitCode", orderEntity.getUnitCode());
  688. map.put("GrossWeight", orderEntity.getGrossWeight());
  689. map.put("NetWeight", orderEntity.getNetWeight());
  690. list.add(map);
  691. }
  692. }
  693. ee.addSheetByMap("订单信息", list, header);
  694. ee.export(response);
  695. return R.ok();
  696. }
  697. /**
  698. * 订单修改已发货的快递信息
  699. */
  700. @RequestMapping("/updateExpressInfo")
  701. @RequiresPermissions("order:updateExpressInfo")
  702. public Object updateExpressInfo(@RequestBody OrderEntity orderEntity) {
  703. OrderEntity orderInfo = orderService.queryObject(orderEntity.getId());
  704. if (orderInfo != null){
  705. if(orderInfo.getShippingStatus() == Integer.parseInt(Dict.shippingStatus.item_1.getItem())) {
  706. OrderEntity order = new OrderEntity();
  707. order.setId(orderInfo.getId());
  708. order.setShippingCode(orderEntity.getShippingCode());
  709. Map map = new HashMap();
  710. map.put("code", orderEntity.getShippingCode());
  711. ShippingEntity shippingEntity = shippingService.queryObjectByCode(orderEntity.getShippingCode());
  712. if(shippingEntity != null) {
  713. order.setShippingName(shippingEntity.getName());
  714. }else{
  715. throw new RRException("此订单修改的快递公司信息不存在!不能操作");
  716. }
  717. order.setShippingNo(orderEntity.getShippingNo());
  718. order.setModerSn(ShiroUtils.getUserEntity().getUsername());
  719. order.setModTime(new Date());
  720. orderService.update(order);
  721. }else{
  722. throw new RRException("此订单"+Dict.shippingStatus.valueOf("item_"+orderInfo.getShippingStatus()).getItemName()+"!不能操作");
  723. }
  724. }
  725. return R.ok();
  726. }
  727. /**
  728. * 上传文件
  729. */
  730. @RequestMapping("/expressUpload")
  731. public R expressUpload(@RequestParam("file") MultipartFile file) {
  732. List<OrderExpressDto> orderExpressList = new ArrayList<>();//快递信息
  733. try {
  734. Map<String, Object> beans = new HashMap<String, Object>();
  735. beans.put("OrderExpressList", orderExpressList);
  736. if (file.isEmpty()) {
  737. return R.error("文件不能为空!");
  738. }
  739. excelUtil.readExcel(JxlsXmlTemplateName.ORDER_EXPRESS_LIST, beans, file.getInputStream());
  740. } catch (Exception e) {
  741. e.printStackTrace();
  742. return R.error("导入失败!");
  743. }
  744. orderService.uploadExcel(orderExpressList);
  745. //上传文件
  746. return R.ok();
  747. }
  748. /**
  749. * 获取ccnet需要重发的订单数据
  750. */
  751. @RequestMapping("/wxOrderResendQueryAllList")
  752. public R wxOrderResendQueryAllList(@RequestParam Map<String, Object> params) {
  753. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  754. //查询列表数据
  755. Query query = new Query(params);
  756. List<WxOrderEntity> orderList = orderService.wxOrderResendQueryAllList(query);
  757. PageUtils pageUtil = new PageUtils(orderList, orderList.size(), query.getLimit(), query.getPage());
  758. return R.ok().put("page", pageUtil);
  759. }
  760. }