OrderController.java 38 KB

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