OrderController.java 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822
  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. orderRefund.setModTime(new Date());
  349. orderRefund.setOutRefundNo(tradeResult.getString("ord_no"));
  350. if (mallOrderRefund != null) {
  351. orderRefund.setId(mallOrderRefund.getId());
  352. orderRefundService.update(orderRefund);//退款记录
  353. }
  354. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  355. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  356. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  357. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  358. mallOrderExceptionRecord.setExceptionContent("退款失败");
  359. mallOrderExceptionRecord.setCreateTime(new Date());
  360. orderExceptionRecordService.save(mallOrderExceptionRecord);
  361. return "发起平安支付退款失败!";
  362. }
  363. } else {
  364. return responseDto.getMsg();
  365. }
  366. }
  367. return "";
  368. }
  369. /**
  370. * 微信申请退款
  371. * @param orderInfo
  372. * @param totalActualPrice
  373. * @return
  374. */
  375. private String wxRefund(OrderEntity orderInfo,Double totalActualPrice){
  376. WechatRefundApiResult result = WechatUtil.wxRefund(orderInfo.getMerchOrderSn().toString(), totalActualPrice,
  377. orderInfo.getActualPrice().doubleValue());
  378. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  379. orderService.refund(orderInfo, result);
  380. } else {
  381. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  382. OrderRefundEntity orderRefund = new OrderRefundEntity();
  383. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  384. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  385. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  386. orderRefund.setModTime(new Date());
  387. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  388. if (mallOrderRefund != null) {
  389. orderRefund.setId(mallOrderRefund.getId());
  390. orderRefundService.update(orderRefund);//退款记录
  391. }
  392. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  393. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  394. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  395. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  396. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  397. mallOrderExceptionRecord.setCreateTime(new Date());
  398. orderExceptionRecordService.save(mallOrderExceptionRecord);
  399. return result.getErr_code_des();
  400. }
  401. return "";
  402. }
  403. /**
  404. * 微信国际申请退款
  405. * @param orderInfo
  406. * @param totalActualPrice
  407. * @return
  408. */
  409. private String wxGlobalRefund(OrderEntity orderInfo,Double totalActualPrice){
  410. WechatGlobalRefundApiResult result = WechatGlobalUtil.wxRefund(orderInfo.getMerchOrderSn().toString(), totalActualPrice,
  411. orderInfo.getActualPrice().doubleValue());
  412. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  413. orderService.globalRefund(orderInfo, result);
  414. } else {
  415. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  416. OrderRefundEntity orderRefund = new OrderRefundEntity();
  417. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  418. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  419. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  420. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  421. orderRefund.setModTime(new Date());
  422. if (mallOrderRefund != null) {
  423. orderRefund.setId(mallOrderRefund.getId());
  424. orderRefundService.update(orderRefund);//退款记录
  425. }
  426. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  427. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  428. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  429. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  430. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  431. mallOrderExceptionRecord.setCreateTime(new Date());
  432. orderExceptionRecordService.save(mallOrderExceptionRecord);
  433. return result.getErr_code_des();
  434. }
  435. return "";
  436. }
  437. /**
  438. * 订单退款请求
  439. */
  440. @RequiresPermissions(value = {"order:offilineRefund"})
  441. @RequestMapping(value = "offilineRefund", method = RequestMethod.POST)
  442. public Object offilineRefund(Long orderId) {
  443. OrderEntity orderInfo = orderService.queryObject(orderId);
  444. if (null == orderInfo) {
  445. return R.error("订单不存在");
  446. }
  447. if (orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_401.getItem()) ||
  448. orderInfo.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_402.getItem())) {
  449. return R.error("订单已退款");
  450. }
  451. if (orderInfo.getOrderStatus() != Integer.parseInt(Dict.orderStatus.item_0.getItem())) {
  452. if (Dict.payFlag.item_cash.getItem().equals(orderInfo.getPayFlag())) {
  453. //现金支付,直接修改订单状态
  454. orderService.refund(orderInfo, null);
  455. } else if (Dict.payFlag.item_weixin.getItem().equals(orderInfo.getPayFlag())) {
  456. //微信线下扫码支付
  457. WechatRefundApiResult result = WechatUtil
  458. .wxRefund(orderInfo.getOrderSnWx(), orderInfo.getActualPrice().doubleValue(),
  459. orderInfo.getActualPrice().doubleValue());
  460. if (result.getResult_code().equals(WechatUtil.WXTradeState.SUCCESS.getCode())) {
  461. orderService.refund(orderInfo, result);
  462. } else {
  463. OrderRefundEntity mallOrderRefund = orderRefundService.queryObjectByOrderId(orderInfo.getId());
  464. OrderRefundEntity orderRefund = new OrderRefundEntity();
  465. orderRefund.setRefundType(Integer.parseInt(Dict.RefundType.item_1.getItem()));
  466. orderRefund.setRefundMoney(BigDecimal.valueOf(orderInfo.getActualPrice().doubleValue()));
  467. orderRefund.setRefundStatus(Integer.parseInt(Dict.RefundStatus.item_4.getItem()));
  468. // orderRefund.setOutRefundNo(result.getOut_refund_no());
  469. orderRefund.setModTime(new Date());
  470. if (mallOrderRefund != null) {
  471. orderRefund.setId(mallOrderRefund.getId());
  472. orderRefundService.update(orderRefund);//退款记录
  473. }
  474. OrderExceptionRecordEntity mallOrderExceptionRecord = new OrderExceptionRecordEntity();
  475. mallOrderExceptionRecord.setUserId(Integer.parseInt(orderInfo.getUserId() + ""));
  476. mallOrderExceptionRecord.setOrderSn(orderInfo.getOrderSn());
  477. mallOrderExceptionRecord.setExceptionStatus(Dict.exceptionStatus.item_03.getItem());
  478. mallOrderExceptionRecord.setExceptionContent("退款失败" + result.getErr_code_des());
  479. mallOrderExceptionRecord.setCreateTime(new Date());
  480. orderExceptionRecordService.save(mallOrderExceptionRecord);
  481. return R.error(result.getErr_code_des());
  482. }
  483. }
  484. }
  485. return R.ok("退款成功");
  486. }
  487. /**
  488. * 获取首页展示信息--会员购买率相关
  489. *
  490. * @param params
  491. * @return
  492. */
  493. @RequestMapping("/getUserOrderInfo")
  494. public R getUserOrderInfo(@RequestParam Map<String, Object> params) {
  495. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  496. int result = orderService.getUserOrderInfo(params);
  497. return R.ok().put("result", result);
  498. }
  499. @RequiresPermissions(value = {"order:orderSubmit"})
  500. @RequestMapping(value = "orderSubmit", method = RequestMethod.POST)
  501. @ResponseBody
  502. public R orderSubmit(@RequestBody List<OfflineCartEntity> offlineCartEntityList) {
  503. Map resultObj = null;
  504. try {
  505. SysUserEntity user = ShiroUtils.getUserEntity();
  506. resultObj = orderService.orderSubmit(offlineCartEntityList, user);
  507. if (((Integer) resultObj.get("errno")) != 0) {
  508. return R.error((String) resultObj.get("errmsg"));
  509. }
  510. } catch (Exception e) {
  511. e.printStackTrace();
  512. }
  513. return R.ok("订单提交成功");
  514. }
  515. /**
  516. * 确认付款
  517. *
  518. * @param id
  519. * @return
  520. */
  521. @RequestMapping("/confirmPay")
  522. @RequiresPermissions("order:confirmPay")
  523. public R confirmPay(@RequestBody Long id) {
  524. orderService.confirmPay(id, Dict.payFlag.item_cash.getItem(), null);
  525. return R.ok();
  526. }
  527. @RequestMapping("/offilineOrderList")
  528. @RequiresPermissions("order:offilineOrderList")
  529. public R offilineOrderList(@RequestParam Map<String, Object> params) {
  530. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  531. //查询列表数据
  532. Query query = new Query(params);
  533. query.put("isOnfiilineOrder", Dict.isOnfflineOrder.item_1.getItem());
  534. List<OrderEntity> orderList = orderService.queryOffilineOrderList(query);
  535. int total = orderService.queryTotal(query);
  536. PageUtils pageUtil = new PageUtils(orderList, total, query.getLimit(), query.getPage());
  537. return R.ok().put("page", pageUtil);
  538. }
  539. @RequestMapping("/offlineInfos/{id}")
  540. @RequiresPermissions("order:offlineInfos")
  541. public R queryObjectBySysUser(@PathVariable("id") Long id) {
  542. OrderEntity order = orderService.queryObjectBySysUser(id);
  543. List<OrderWXPayRecordEntity> payRecords = orderWXPayRecordService.getRecordsByOutTradeNo(order.getOrderSn());
  544. order.setPayRecordList(payRecords);
  545. return R.ok().put("order", order);
  546. }
  547. @RequestMapping("/wxMicropayPay")
  548. @RequiresPermissions("order:wxMicropayPay")
  549. public R wxMicropayPay(Long id, String auth_code) {
  550. R r = null;
  551. SysUserEntity user = ShiroUtils.getUserEntity();
  552. if (user == null) {
  553. throw new RRException("用户登录超时,请重新登录");
  554. }
  555. if (!user.getRoleType().equalsIgnoreCase("2")) {
  556. throw new RRException("该操作只允许店员账户操作");
  557. }
  558. OrderEntity orderEntity = orderService.queryObject(id);
  559. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_201.getItem())) {
  560. throw new RRException("此订单已付款!");
  561. }
  562. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_301.getItem())) {
  563. throw new RRException("此订单已完成!");
  564. }
  565. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_101.getItem())) {
  566. throw new RRException("此订单已取消!");
  567. }
  568. if (orderEntity.getOrderStatus() == Integer.parseInt(Dict.orderStatus.item_102.getItem())) {
  569. throw new RRException("此订单已删除!");
  570. }
  571. //保存支付记录
  572. OrderWXPayRecordEntity orderWXPayRecordCurrent = orderWXPayRecordService.saveRecord(orderEntity);
  573. StoreEntity store = storeService.queryObject(orderEntity.getStoreId());
  574. WechatMicropayApiResult wechatMicropayApiResult = WechatUtil
  575. .wxMicropay(store.getMerchName() + "-" + store.getStoreName(), orderEntity.getOrderBizType(), null,
  576. orderWXPayRecordCurrent.getOutTradeNoWX(), orderEntity.getActualPrice().doubleValue(),
  577. "127.0.0.1", auth_code);
  578. orderWXPayRecordService.updateRecord(orderWXPayRecordCurrent.getId(), wechatMicropayApiResult);
  579. //当支付成功时,修改订单,并把其他支付记录撤销
  580. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  581. //查询当前订单所有的支付记录
  582. List<OrderWXPayRecordEntity> orderWXPayRecordEntitys =
  583. orderWXPayRecordService.getRecordsByOutTradeNo(orderEntity.getOrderSn());
  584. for (OrderWXPayRecordEntity orderWXPayRecordTemp : orderWXPayRecordEntitys) {
  585. //查询出来的记录不等于当前记录,并且未撤销,未关闭时,撤销订单
  586. if (orderWXPayRecordTemp.getId() != orderWXPayRecordCurrent.getId() &&
  587. (!WechatUtil.WXTradeState.REVOKED.getCode().equals(orderWXPayRecordTemp.getTradeState()) ||
  588. !WechatUtil.WXTradeState.CLOSED.getCode().equals(orderWXPayRecordTemp.getTradeState()))) {
  589. WechatReverseApiResult wechatReverseApiResult =
  590. WechatUtil.wxReverse(orderWXPayRecordTemp.getOutTradeNoWX());
  591. //撤销订单成功
  592. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getReturn_code()) &&
  593. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getResult_code())) {
  594. //调用订单查询接口
  595. WechatRefundApiResult wechatRefundApiResult =
  596. WechatUtil.wxOrderQuery(orderWXPayRecordTemp.getOutTradeNoWX());
  597. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getReturn_code()) &&
  598. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getResult_code())) {
  599. // 修改订单支付记录
  600. orderWXPayRecordService
  601. .updateWXPayRecordTradeState(orderWXPayRecordTemp.getId(), wechatRefundApiResult);
  602. }
  603. }
  604. }
  605. }
  606. orderService.confirmPay(id, Dict.payFlag.item_weixin.getItem(), orderWXPayRecordCurrent.getOutTradeNoWX());
  607. r = R.ok();
  608. //用户支付中
  609. } else if (WechatUtil.WXTradeState.USERPAYING.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  610. r = R.error(WechatUtil.WXTradeState.USERPAYING.getCodeZn() + ",稍等片刻后请刷新页面重新查看订单状态");
  611. //用户支付失败
  612. } else if (WechatUtil.WXTradeState.PAYERROR.getCode().equals(wechatMicropayApiResult.getTrade_state())) {
  613. WechatReverseApiResult wechatReverseApiResult =
  614. WechatUtil.wxReverse(orderWXPayRecordCurrent.getOutTradeNoWX());
  615. //撤销订单成功
  616. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getReturn_code()) &&
  617. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatReverseApiResult.getResult_code())) {
  618. //调用订单查询接口
  619. WechatRefundApiResult wechatRefundApiResult =
  620. WechatUtil.wxOrderQuery(orderWXPayRecordCurrent.getOutTradeNoWX());
  621. if (WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getReturn_code()) &&
  622. WechatUtil.WXTradeState.SUCCESS.getCode().equals(wechatRefundApiResult.getResult_code())) {
  623. // 修改订单支付记录
  624. orderWXPayRecordService
  625. .updateWXPayRecordTradeState(orderWXPayRecordCurrent.getId(), wechatRefundApiResult);
  626. }
  627. r = R.error(orderWXPayRecordCurrent.getErrCodeDes());
  628. } else {
  629. r = R.error(wechatReverseApiResult.getErr_code_des());
  630. }
  631. }
  632. return r;
  633. }
  634. /**
  635. * 订单导出请求
  636. */
  637. @RequiresPermissions(value = {"order:export"})
  638. @RequestMapping(value = "export")
  639. public Object export(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  640. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  641. params = ParamUtils.setTimeMap(params);
  642. //查询列表数据
  643. params.put("isOnfiilineOrder", Dict.isOnfflineOrder.item_0.getItem());
  644. List<OrderEntity> orderList = orderService.queryExportList(params);
  645. ExcelExport ee = new ExcelExport("订单信息");
  646. String[] header = new String[]{"订单编号","商户订单编号", "所属门店", "供应商", "订单状态", "SKU", "商品名称", "数量", "销售价", "实际支付金额", "保税模式", "快递公司名称", "快递单编号", "海关清单编号", "收货人姓名", "收件人手机", "收件人省份", "收件人城市", "收件人区县", "收件人地址", "下单时间", "支付流水号","身份证号"
  647. ,"原产国","规格型号","品牌","单位","毛重(kg)","净重"};
  648. List<Map<String, Object>> list = new ArrayList<>();
  649. if (orderList != null && orderList.size() != 0) {
  650. for (OrderEntity orderEntity : orderList) {
  651. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  652. Integer orderStatus = orderEntity.getOrderStatus();
  653. String orderBizType = orderEntity.getOrderBizType();
  654. map.put("OrderSn", orderEntity.getOrderSn());
  655. map.put("MerchOrderSn", orderEntity.getMerchOrderSn());
  656. map.put("StoreName", orderEntity.getStoreName());
  657. map.put("SupplierThirdPartyMerchName", orderEntity.getSupplierThirdPartyMerchName());
  658. map.put("OrderStatus", StringUtils.isEmpty(orderStatus.toString())? "":Dict.orderStatus.valueOf("item_"+ orderStatus).getItemName());
  659. map.put("SKU", orderEntity.getSku());
  660. map.put("GoodsName", orderEntity.getGoodsName());
  661. map.put("Number", orderEntity.getNumber());
  662. map.put("RetailPrice", orderEntity.getRetailPrice());
  663. map.put("ActualPrice", orderEntity.getActualPrice());
  664. map.put("OrderBizType", StringUtils.isEmpty(orderBizType)? "":Dict.orderBizType.valueOf("item_"+orderBizType).getItemName());
  665. map.put("ShippingName", orderEntity.getShippingName());
  666. map.put("ShippingNo", orderEntity.getShippingNo());
  667. map.put("InvtNo", orderEntity.getOrderProcessRecord()==null?"":orderEntity.getOrderProcessRecord().getInvtNo());
  668. map.put("Consignee", orderEntity.getConsignee());
  669. map.put("Mobile", orderEntity.getMobile());
  670. map.put("Province", orderEntity.getProvince());
  671. map.put("City", orderEntity.getCity());
  672. map.put("District", orderEntity.getDistrict());
  673. map.put("Address", orderEntity.getAddress());
  674. map.put("OrderStartTime", orderEntity.getOrderProcessRecord()==null?"":DateUtils.format(orderEntity.getOrderProcessRecord().getAddOrderStartTime(),"yyyy-MM-dd HH:mm:ss"));
  675. map.put("PayId", orderEntity.getPayTransactionId());
  676. map.put("IdNo", orderEntity.getIdNo());
  677. map.put("OriCntCode", orderEntity.getOriCntCode());
  678. map.put("CiqProdModel", orderEntity.getCiqProdModel());
  679. map.put("Brand", orderEntity.getBrand());
  680. map.put("UnitCode", orderEntity.getUnitCode());
  681. map.put("GrossWeight", orderEntity.getGrossWeight());
  682. map.put("NetWeight", orderEntity.getNetWeight());
  683. list.add(map);
  684. }
  685. }
  686. ee.addSheetByMap("订单信息", list, header);
  687. ee.export(response);
  688. return R.ok();
  689. }
  690. /**
  691. * 订单修改已发货的快递信息
  692. */
  693. @RequestMapping("/updateExpressInfo")
  694. @RequiresPermissions("order:updateExpressInfo")
  695. public Object updateExpressInfo(@RequestBody OrderEntity orderEntity) {
  696. OrderEntity orderInfo = orderService.queryObject(orderEntity.getId());
  697. if (orderInfo != null){
  698. if(orderInfo.getShippingStatus() == Integer.parseInt(Dict.shippingStatus.item_1.getItem())) {
  699. OrderEntity order = new OrderEntity();
  700. order.setId(orderInfo.getId());
  701. order.setShippingCode(orderEntity.getShippingCode());
  702. Map map = new HashMap();
  703. map.put("code", orderEntity.getShippingCode());
  704. ShippingEntity shippingEntity = shippingService.queryObjectByCode(orderEntity.getShippingCode());
  705. if(shippingEntity != null) {
  706. order.setShippingName(shippingEntity.getName());
  707. }else{
  708. throw new RRException("此订单修改的快递公司信息不存在!不能操作");
  709. }
  710. order.setShippingNo(orderEntity.getShippingNo());
  711. order.setModerSn(ShiroUtils.getUserEntity().getUsername());
  712. order.setModTime(new Date());
  713. orderService.update(order);
  714. }else{
  715. throw new RRException("此订单"+Dict.shippingStatus.valueOf("item_"+orderInfo.getShippingStatus()).getItemName()+"!不能操作");
  716. }
  717. }
  718. return R.ok();
  719. }
  720. /**
  721. * 上传文件
  722. */
  723. @RequestMapping("/expressUpload")
  724. public R expressUpload(@RequestParam("file") MultipartFile file) {
  725. List<OrderExpressDto> orderExpressList = new ArrayList<>();//快递信息
  726. try {
  727. Map<String, Object> beans = new HashMap<String, Object>();
  728. beans.put("OrderExpressList", orderExpressList);
  729. if (file.isEmpty()) {
  730. return R.error("文件不能为空!");
  731. }
  732. excelUtil.readExcel(JxlsXmlTemplateName.ORDER_EXPRESS_LIST, beans, file.getInputStream());
  733. } catch (Exception e) {
  734. e.printStackTrace();
  735. return R.error("导入失败!");
  736. }
  737. orderService.uploadExcel(orderExpressList);
  738. //上传文件
  739. return R.ok();
  740. }
  741. /**
  742. * 获取ccnet需要重发的订单数据
  743. */
  744. @RequestMapping("/wxOrderResendQueryAllList")
  745. public R wxOrderResendQueryAllList(@RequestParam Map<String, Object> params) {
  746. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  747. //查询列表数据
  748. Query query = new Query(params);
  749. List<WxOrderEntity> orderList = orderService.wxOrderResendQueryAllList(query);
  750. PageUtils pageUtil = new PageUtils(orderList, orderList.size(), query.getLimit(), query.getPage());
  751. return R.ok().put("page", pageUtil);
  752. }
  753. }