AppBookingAction.java 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922
  1. package com.happy.action;
  2. import com.happy.Model.AdminManager;
  3. import com.happy.Model.Booking;
  4. import com.happy.Model.weixin.PayResult;
  5. import com.happy.Model.weixin.Users;
  6. import com.happy.Model.weixin.WechatUnifiedOrder;
  7. import com.happy.Model.weixin.WeiXinUtil;
  8. import com.happy.Until.*;
  9. import com.happy.Until.Enum.B;
  10. import com.happy.Until.Enum.OrderEnum;
  11. import com.happy.Until.Enum.PayEnum;
  12. import com.happy.Until.weixin.EndPay;
  13. import com.happy.Until.weixin.JaxbUtil;
  14. import com.happy.Until.weixin.PayWxUtil;
  15. import com.happy.Until.weixin.TongYiReturn;
  16. import com.happy.common.http.Message;
  17. import com.happy.common.http.Message2;
  18. import com.happy.common.wx.WxUtil;
  19. import com.happy.constant.ResultStatusCode;
  20. import com.happy.service.AdminManagerService;
  21. import com.happy.service.AppBookService;
  22. import com.happy.service.BookService;
  23. import com.happy.service.UserService;
  24. import com.opensymphony.xwork2.ActionSupport;
  25. import net.sf.json.JSONObject;
  26. import org.apache.struts2.ServletActionContext;
  27. import org.apache.struts2.interceptor.ServletRequestAware;
  28. import javax.annotation.Resource;
  29. import javax.servlet.http.HttpServletRequest;
  30. import javax.servlet.http.HttpServletResponse;
  31. import java.io.BufferedReader;
  32. import java.io.PrintWriter;
  33. import java.text.ParseException;
  34. import java.util.*;
  35. /**
  36. * 订单进去Action请求交互
  37. */
  38. public class AppBookingAction extends ActionSupport implements ServletRequestAware {
  39. private HttpServletRequest request;
  40. public HttpServletResponse response;
  41. @Resource
  42. public BookService bookService;
  43. @Resource
  44. public UserService userService;
  45. @Resource
  46. public AppBookService appBookService;
  47. @Resource
  48. public AdminManagerService adminManagerService;
  49. public int page; // 当前页
  50. public int rows;// 每页显示的行数rows
  51. public Integer id;
  52. public String status;
  53. public String hotelId; // 酒店id
  54. public String houseId; // 房型id
  55. public String startTime; // 订房开始时间
  56. public String endTime; // 订房结束时间
  57. public String houseOrderNumber; // 订房数量
  58. public String userName; // 住客姓名
  59. public String userPhone; // 住客联系电话
  60. public String userId; // 下单人id
  61. public String getBookingId() {
  62. return bookingId;
  63. }
  64. public void setBookingId(String bookingId) {
  65. this.bookingId = bookingId;
  66. }
  67. private String bookingId; // 订单Id
  68. private String open_id; // 用户open_Id
  69. public HttpServletRequest getRequest() {
  70. return request;
  71. }
  72. public void setRequest(HttpServletRequest request) {
  73. this.request = request;
  74. }
  75. public void setServletRequest(HttpServletRequest request) {
  76. this.request = request;
  77. }
  78. public HttpServletResponse getResponse() {
  79. return response;
  80. }
  81. public void setResponse(HttpServletResponse response) {
  82. this.response = response;
  83. }
  84. public int getPage() {
  85. return page;
  86. }
  87. public void setPage(int page) {
  88. this.page = page;
  89. }
  90. public int getRows() {
  91. return rows;
  92. }
  93. public void setRows(int rows) {
  94. this.rows = rows;
  95. }
  96. public Integer getId() {
  97. return id;
  98. }
  99. public void setId(Integer id) {
  100. this.id = id;
  101. }
  102. public String getStatus() {
  103. return status;
  104. }
  105. public void setStatus(String status) {
  106. this.status = status;
  107. }
  108. /**
  109. * 定时任务
  110. * @return
  111. */
  112. public String scheduledTasks()
  113. {
  114. // 获取所有的订单待支付状态
  115. StringBuffer strSqlBook = new StringBuffer();
  116. strSqlBook.append(" and order_status = '").append(PayEnum.待支付.getNum()).append("' ");
  117. List<Booking> bookingList = bookService.queryList(strSqlBook.toString());
  118. if (bookingList == null || bookingList.size() <= 0){
  119. return null;
  120. }
  121. try {
  122. for (Booking booking: bookingList) {
  123. if (booking == null || Func.checkNull(booking.getCreateTime()) || Func.checkNull(booking.getLockTime()))
  124. continue;
  125. Date createTime = DateUtil.parseDate(booking.getCreateTime(),DateUtil.Time_Formatter_Second);
  126. // 对订单时间进行累加
  127. String lockTime = TimeExchange.TimeRangeM(DateUtil.getFormatPaternDate(createTime),Func.parseInt(booking.getLockTime()));
  128. // 当前时间 大于 锁定时间 为true 且支付状态
  129. boolean flag = TimeExchange.CompareDate(lockTime, TimeExchange.getDate());
  130. if (flag)
  131. {
  132. // 如果超时,则将订单状态修改为已超时
  133. booking.setOrderStatus(Func.parseStr(PayEnum.支付超时.getNum()));
  134. booking.setUpdateTime(TimeExchange.getDate());
  135. bookService.updateBooking(booking);
  136. System.out.println("已将订单"+booking.getOrderNum()+"标识为支付超时");
  137. }
  138. }
  139. } catch (ParseException e) {
  140. e.printStackTrace();
  141. }
  142. return null;
  143. }
  144. /**
  145. * 进行更新数据将订单状态修改为已超时。
  146. * @return
  147. */
  148. public String updateOrderStatus()
  149. {
  150. JSONObject jsonObject = new JSONObject();
  151. if (Func.checkNull(bookingId))
  152. {
  153. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  154. jsonObject.put(B.message, "未传入bookingId---updateOrderStatus");
  155. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  156. return null;
  157. }
  158. try {
  159. Booking booking = bookService.getById(Func.parseInt(bookingId));
  160. Date createTime = DateUtil.parseDate(booking.getCreateTime(),DateUtil.Time_Formatter_Second);
  161. // 对订单时间进行累加
  162. String lockTime = TimeExchange.TimeRangeM(DateUtil.getFormatPaternDate(createTime), Func.parseInt(booking.getLockTime()));
  163. // 当前时间 大于 锁定时间 为true 且支付状态
  164. boolean flag = TimeExchange.CompareDate(lockTime, TimeExchange.getDate());
  165. if (flag)
  166. {
  167. // 如果超时,则将订单状态修改为已超时
  168. booking.setOrderStatus(Func.parseStr(PayEnum.支付超时.getNum()));
  169. booking.setUpdateTime(TimeExchange.getDate());
  170. bookService.updateBooking(booking);
  171. System.out.println("已将订单"+booking.getOrderNum()+"标识为支付超时");
  172. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  173. jsonObject.put(B.message, "已将订单"+booking.getOrderNum()+"标识为支付超时");
  174. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  175. }
  176. } catch (ParseException e) {
  177. throw new RuntimeException(e);
  178. }
  179. return null;
  180. }
  181. /**
  182. * houseId; // 房型id
  183. * startTime; // 订房开始时间 2023/08/04
  184. * endTime; // 订房结束时间 2023/08/05
  185. * houseOrderNumber; // 订房数量
  186. * userName; // 住客姓名
  187. * userPhone; // 住客联系电话
  188. * userId; // 下单人id
  189. * 用户点击订房操作,生成订单
  190. */
  191. public String createOrder() {
  192. // 插入订单数据到表中
  193. JSONObject jsonObject = new JSONObject();
  194. if (Func.checkNull(houseId) || Func.checkNull(startTime) || Func.checkNull(endTime)
  195. || Func.checkNull(houseOrderNumber) || Func.checkNull(userName) || Func.checkNull(userPhone) || Func.checkNull(userId)) {
  196. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  197. jsonObject.put(B.message, ResultStatusCode.BAD_REQUEST.getMsg());
  198. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  199. return null;
  200. }
  201. // 将时间统一转化为 yyyy/MM/dd
  202. String startDate = DateUtil.parseDateToStr((Func.parseDate(startTime)), DateUtil.Time_Formatter_Day);
  203. String endDate = DateUtil.parseDateToStr((Func.parseDate(endTime)), DateUtil.Time_Formatter_Day);
  204. // 创建订单之前,先验证是否有房间
  205. String backMessage = appBookService.varificationHouse(houseId, startDate, endDate);
  206. if (!Func.checkNull(backMessage)) {
  207. jsonObject.put(B.code, ResultStatusCode.CANNTBOOKING.getStatus());
  208. jsonObject.put(B.message, backMessage);
  209. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  210. return null;
  211. }
  212. String bookingId= Func.parseStr(UUIDUtil.generateID());
  213. String mess = appBookService.createOrder(bookingId, houseId, startDate, endDate, houseOrderNumber, userName, userPhone, userId);
  214. if (!Func.checkNull(mess)) {
  215. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  216. jsonObject.put(B.message, mess);
  217. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  218. return null;
  219. }
  220. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  221. jsonObject.put(B.message, ResultStatusCode.OK.getMsg());
  222. jsonObject.put(B.data, bookingId);
  223. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  224. return null;
  225. }
  226. // /**
  227. // * 再次预订
  228. // *
  229. // * @return
  230. // */
  231. // public String reCreateOrder() {
  232. // // 插入订单数据到表中
  233. // JSONObject jsonObject = new JSONObject();
  234. // if (Func.checkNull(houseId) || Func.checkNull(startTime) || Func.checkNull(endTime)
  235. // || Func.checkNull(houseOrderNumber) || Func.checkNull(userName) || Func.checkNull(userPhone) || Func.checkNull(userId)) {
  236. // jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  237. // jsonObject.put(B.message, ResultStatusCode.BAD_REQUEST.getMsg());
  238. // ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  239. // return null;
  240. // }
  241. //
  242. // // 将时间统一转化为 yyyy/MM/dd
  243. // String startDate = DateUtil.parseDateToStr((Func.parseDate(startTime)), DateUtil.Time_Formatter_Day);
  244. // String endDate = DateUtil.parseDateToStr((Func.parseDate(endTime)), DateUtil.Time_Formatter_Day);
  245. //
  246. // // 创建订单之前,先验证是否有房间
  247. // String backMessage = appBookService.varificationHouse(houseId, startDate, endDate);
  248. // if (Func.checkNull(backMessage)) {
  249. // jsonObject.put(B.code, ResultStatusCode.CANNTBOOKING.getStatus());
  250. // jsonObject.put(B.message, backMessage);
  251. // ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  252. // return null;
  253. // }
  254. //
  255. // appBookService.reCreateOrder(houseId, startTime, endTime, houseOrderNumber, userName, userPhone, userId);
  256. //
  257. // jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  258. // jsonObject.put(B.message, ResultStatusCode.OK.getMsg());
  259. // ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  260. // return null;
  261. // }
  262. /**
  263. * bookingId 订单id
  264. * 商家在已支付,待入住时点退单 ,进入退款流程后退单
  265. * 在已入住,时点退单,进入退款流程后退款
  266. * @return
  267. */
  268. public String chargeback() throws Exception {
  269. if (Func.checkNull(bookingId))
  270. return null;
  271. JSONObject jsonObject = new JSONObject();
  272. Booking book = bookService.getById(Func.parseInt(bookingId));
  273. Users users = userService.queryByUserId(book.getCreateUserid());
  274. if (book == null || users == null)
  275. return null;
  276. //1待支付,2已支付,3待入住,4已入住,5已消费,6支付超时,7已取消,8已退单,9已退款,10退款中
  277. int status = Func.parseInt(book.getOrderStatus());
  278. if (status == 1)
  279. {
  280. book.setOrderStatus(Func.parseStr(PayEnum.已取消.getNum())); // 如果在1待支付情况,用户点击取消订单按钮,后台直接修改取消订单操作
  281. book.setUpdateTime(DateUtil.getFormatPaternDate(new Date()));
  282. bookService.updateBooking(book);
  283. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  284. jsonObject.put(B.message, ResultStatusCode.OK.getMsg());
  285. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  286. return null;
  287. }else if (status == 2 || status == 3)
  288. {
  289. book.setOrderStatus(Func.parseStr(PayEnum.退款中.getNum())); // 如果在2已支付,3待入住 情况,商家点击取消订单按钮,后台先修改状态为退款中,然后走退款流程
  290. book.setRemake(Func.parseStr(PayEnum.已退单.getPayStatus()));
  291. }else if(status == 4)
  292. {
  293. book.setOrderStatus(Func.parseStr(PayEnum.退款中.getNum())); // 如果在2已支付,3待入住 情况,商家点击取消订单按钮,后台先修改状态为退款中,然后走退款流程
  294. book.setRemake(Func.parseStr(PayEnum.已退款.getPayStatus()));
  295. }
  296. if (book.getPayAccount() > 0)
  297. {
  298. // 注明如果支付金额大于0,则需要退款: (标识走退款操作)
  299. book.setRefundWay(OrderEnum.微信退款.toString());
  300. }
  301. jsonObject = refundMethod(book,users.getOpenid());
  302. ResUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  303. return null;
  304. }
  305. /**
  306. * bookingId 订单id
  307. * open_id
  308. * 取消订单功能: 用户点击
  309. * //1待支付,2已支付,3待入住,4已入住,5已消费,6支付超时,7已取消,8已退单,9已退款,10退款中
  310. *
  311. * @return
  312. */
  313. public String cancelBooking() throws Exception {
  314. JSONObject jsonObject = new JSONObject();
  315. if (Func.checkNull(this.bookingId)) {
  316. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  317. jsonObject.put(B.message, "未传入bookingId");
  318. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  319. return null;
  320. }
  321. // 取消订单,修改订单的支付状态
  322. Booking book = bookService.getById(Func.parseInt(bookingId));
  323. if (book == null )
  324. {
  325. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  326. jsonObject.put(B.message, "未获取到订单信息,请重新查询");
  327. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  328. return null;
  329. }
  330. //是否能取消订单(1是 2否)
  331. if (Func.parseInt(book.getHotelIsCanorder()) == 2)
  332. {
  333. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  334. jsonObject.put(B.message, "商家设置不可取消订单,请联系商家");
  335. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  336. return null;
  337. }
  338. AdminManager adminManager = adminManagerService.getById(Func.parseInt(book.getHotelManagerId()));
  339. //1待支付,2已支付,3待入住,4已入住,5已消费,6支付超时,7已取消,8已退单,9已退款,10退款中
  340. int status = Func.parseInt(book.getOrderStatus());
  341. if (status == 1)
  342. {
  343. book.setOrderStatus(Func.parseStr(PayEnum.已取消.getNum())); // 如果在1待支付情况,用户点击取消订单按钮,后台直接修改取消订单操作
  344. book.setUpdateTime(DateUtil.getFormatPaternDate(new Date()));
  345. book.setRemake(Func.parseStr(PayEnum.已取消.getPayStatus()));
  346. bookService.updateBooking(book);
  347. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  348. jsonObject.put(B.message, "已取消订单");
  349. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  350. return null;
  351. }else if (status == 2 || status == 3)
  352. {
  353. // 如果在2已支付,3待入住 情况,用户点击取消订单按钮,后台先修改状态为退款中,然后走退款流程
  354. book.setOrderStatus(Func.parseStr(PayEnum.退款中.getNum()));
  355. book.setUpdateTime(DateUtil.getFormatPaternDate(new Date()));
  356. book.setRemake(Func.parseStr(PayEnum.已取消.getPayStatus()));
  357. if (book.getPayAccount() > 0)
  358. {
  359. // 注明如果支付金额大于0,则需要退款: (标识走退款操作)
  360. book.setRefundWay(OrderEnum.微信退款.toString());
  361. }
  362. }
  363. Users users = userService.queryByUserId(book.getCreateUserid()); // 用户信息
  364. if (users == null) {
  365. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  366. jsonObject.put(B.message, "未查询到当前用户数据users,请先授权");
  367. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  368. return null;
  369. }
  370. // 退款操作
  371. jsonObject = refundMethod(book,users.getOpenid());
  372. jsonObject.put(B.data, book);
  373. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  374. return null;
  375. }
  376. /**
  377. * 退款方法
  378. * @param book
  379. * @param open_id
  380. * @return
  381. * @throws Exception
  382. */
  383. public JSONObject refundMethod(Booking book,String open_id) throws Exception {
  384. JSONObject jsonObject = new JSONObject();
  385. if (book == null || Func.checkNull(open_id))
  386. {
  387. jsonObject.put("code", 400);
  388. jsonObject.put("message", "未传入book和open_id数据---refundMethod");
  389. return jsonObject;
  390. }
  391. // 进行判断如果订单是退款中,并且标识字段微信退款,则进入退款流程
  392. if (Func.parseStr(PayEnum.退款中.getNum()).equals(book.getOrderStatus()) && OrderEnum.微信退款.toString().equals(book.getRefundWay())) {
  393. String ip = WeiXinUtil.ip;
  394. double money = book.getPayAccount();
  395. int a = (int) (money * 100);
  396. WechatUnifiedOrder w = new WechatUnifiedOrder();
  397. w.setAppid(WeiXinUtil.appid_c);
  398. w.setAttach("chuanghai");
  399. w.setBody("chuanghai");
  400. w.setMch_id(WeiXinUtil.account);
  401. w.setNonce_str(PayWxUtil.getNonceStr());// 随机支付串
  402. w.setNotify_url(WeiXinUtil.ip_h + "/abkquery_refund.action");// 支付结果回调地址
  403. w.setOpenid(open_id);
  404. w.setOut_trade_no(book.getOrderNum());
  405. String refund_order = WxUtil.mchOrderNo();
  406. w.setOut_refund_no(refund_order); // 退款单号
  407. w.setSpbill_create_ip(ip);
  408. w.setTotal_fee(a);
  409. w.setRefund_fee(a); // 退款金额
  410. w.setTrade_type("JSAPI");
  411. SortedMap<String, String> params = new TreeMap<>();
  412. params.put("appid", w.getAppid());
  413. params.put("mch_id", w.getMch_id());
  414. params.put("nonce_str", w.getNonce_str());
  415. params.put("notify_url", w.getNotify_url());
  416. params.put("out_refund_no", w.getOut_refund_no()); // 退款单号
  417. params.put("out_trade_no", w.getOut_trade_no());
  418. params.put("refund_fee",w.getRefund_fee()+""); // 退款金额
  419. params.put("total_fee", w.getTotal_fee() + "");
  420. w.setSign(PayWxUtil.getSign(params, WeiXinUtil.key));
  421. params.put("sign", w.getSign());
  422. //String retXml = JaxbUtil.getRequestXml(params);
  423. String xml = "<xml>" +
  424. "<appid>" + w.getAppid() + "</appid>" +
  425. "<mch_id>" + w.getMch_id() + "</mch_id>" +
  426. "<nonce_str>" + w.getNonce_str() + "</nonce_str>" +
  427. "<notify_url>" + w.getNotify_url() + "</notify_url>" +
  428. "<out_refund_no>" + w.getOut_refund_no() + "</out_refund_no>" +
  429. "<out_trade_no>" + w.getOut_trade_no() + "</out_trade_no>" +
  430. "<refund_fee>" + w.getRefund_fee()+"" + "</refund_fee>" +
  431. "<total_fee>" + w.getTotal_fee() + "" + "</total_fee>" +
  432. "<sign>" + w.getSign() + "</sign>" +
  433. "</xml>";
  434. //String msg = HttpsClient.sendPost2("https://api.mch.weixin.qq.com/secapi/pay/refund", retXml);
  435. String msg = HttpUtils.post2("https://api.mch.weixin.qq.com/secapi/pay/refund", xml);
  436. if (msg.indexOf("FAIL") > -1) {
  437. jsonObject.put("code", 507);
  438. jsonObject.put("message", "退款失败");
  439. ResUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  440. return null;
  441. }
  442. // 设置订单状态为退款中
  443. book.setOrderStatus(Func.parseStr(PayEnum.退款中.getNum()));
  444. book.setUpdateTime(DateUtil.parseDateToStr(new Date(),DateUtil.Time_Formatter_Second));
  445. bookService.updateBooking(book); // 退款中
  446. jsonObject.put("code", 200);
  447. jsonObject.put("message", "申请已提交,请稍候查询");
  448. return jsonObject;
  449. }
  450. jsonObject.put("code", 400);
  451. jsonObject.put("message", "提交申请失败");
  452. return jsonObject;
  453. }
  454. // /**
  455. // * open_id
  456. // * bookingId
  457. // * 微信退款功能
  458. // */
  459. // public String refundBooking() throws Exception {
  460. // JSONObject resultJson = new JSONObject();
  461. // if (Func.checkNull(this.open_id) || Func.checkNull(this.bookingId)) {
  462. // resultJson.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  463. // resultJson.put(B.message, "未传入open_id和bookingId");
  464. // ResponseUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  465. // return null;
  466. // }
  467. //
  468. // Users users = userService.queryByOpenid(open_id); // 用户信息
  469. // Booking booking = bookService.getById(Func.parseInt(bookingId)); // 订单信息
  470. // if (users == null || booking == null) {
  471. // resultJson.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  472. // resultJson.put(B.message, "未查询到当前用户数据users,请先授权");
  473. // ResponseUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  474. // return null;
  475. // }
  476. //
  477. // String ip = WeiXinUtil.ip;
  478. // double money = booking.getPayAccount();
  479. // int a = (int) (money * 100);
  480. // WechatUnifiedOrder w = new WechatUnifiedOrder();
  481. // w.setAppid(WeiXinUtil.appid_c);
  482. // w.setAttach("chuanghai");
  483. // w.setBody("chuanghai");
  484. // w.setMch_id(WeiXinUtil.account);
  485. // w.setNonce_str(PayWxUtil.getNonceStr());// 随机支付串
  486. // w.setNotify_url(WeiXinUtil.ip_h + "/abkquery_refund.action");// 支付结果回调地址
  487. // w.setOpenid(open_id);
  488. // w.setOut_trade_no(booking.getOrderNum());
  489. // String refund_order = WxUtil.mchOrderNo();
  490. // w.setOut_refund_no(refund_order); // 退款单号
  491. // w.setSpbill_create_ip(ip);
  492. // w.setTotal_fee(a);
  493. // w.setRefund_fee(a); // 退款金额
  494. // w.setTrade_type("JSAPI");
  495. // SortedMap<String, String> params = new TreeMap<>();
  496. // params.put("appid", w.getAppid());
  497. // params.put("mch_id", w.getMch_id());
  498. // params.put("nonce_str", w.getNonce_str());
  499. // params.put("notify_url", w.getNotify_url());
  500. // params.put("out_refund_no", w.getOut_refund_no()); // 退款单号
  501. // params.put("out_trade_no", w.getOut_trade_no());
  502. // params.put("refund_fee",w.getRefund_fee()+""); // 退款金额
  503. // params.put("total_fee", w.getTotal_fee() + "");
  504. //
  505. // w.setSign(PayWxUtil.getSign(params, WeiXinUtil.key));
  506. // params.put("sign", w.getSign());
  507. // //String retXml = JaxbUtil.getRequestXml(params);
  508. // String xml = "<xml>" +
  509. // "<appid>" + w.getAppid() + "</appid>" +
  510. // "<mch_id>" + w.getMch_id() + "</mch_id>" +
  511. // "<nonce_str>" + w.getNonce_str() + "</nonce_str>" +
  512. // "<notify_url>" + w.getNotify_url() + "</notify_url>" +
  513. // "<out_refund_no>" + w.getOut_refund_no() + "</out_refund_no>" +
  514. // "<out_trade_no>" + w.getOut_trade_no() + "</out_trade_no>" +
  515. // "<refund_fee>" + w.getRefund_fee()+"" + "</refund_fee>" +
  516. // "<total_fee>" + w.getTotal_fee() + "" + "</total_fee>" +
  517. // "<sign>" + w.getSign() + "</sign>" +
  518. // "</xml>";
  519. // //String msg = HttpsClient.sendPost2("https://api.mch.weixin.qq.com/secapi/pay/refund", retXml);
  520. // String msg = HttpUtils.post2("https://api.mch.weixin.qq.com/secapi/pay/refund", xml);
  521. // if (msg.indexOf("FAIL") > -1) {
  522. // resultJson.put("code", 507);
  523. // resultJson.put("message", "退款失败");
  524. // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  525. // return null;
  526. // }
  527. //
  528. // // 设置订单状态为退款中
  529. // booking.setOrderStatus(Func.parseStr(PayEnum.TEN.getNum()));
  530. // booking.setUpdateTime(DateUtil.parseDateToStr(new Date(),DateUtil.Time_Formatter_Second));
  531. // bookService.updateBooking(booking); // 退款中
  532. //
  533. // resultJson.put("code", 200);
  534. // resultJson.put("message", "退款申请已提交,请稍候查询");
  535. // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  536. // return null;
  537. // }
  538. /* 退款回调 */
  539. public String query_refund() throws Exception {
  540. // 查询本地数据库中,正在退款中
  541. StringBuffer strSqlBook = new StringBuffer();
  542. strSqlBook.append(" and order_status = '").append(PayEnum.退款中.getNum()).append("' ");
  543. List<Booking> booking = bookService.queryList(strSqlBook.toString());
  544. if (booking==null){
  545. return null;
  546. }
  547. WechatUnifiedOrder w = new WechatUnifiedOrder();
  548. Map<String, String> params = new HashMap<String, String>();
  549. Booking book = new Booking();
  550. for (int i = 0; i < booking.size(); i++) {
  551. if (booking.get(i) == null)
  552. continue;
  553. book = booking.get(i);
  554. w = new WechatUnifiedOrder();
  555. w.setAppid(WeiXinUtil.appid_c);
  556. w.setAttach("chuanghai");
  557. w.setBody("chuanghai");
  558. w.setMch_id(WeiXinUtil.account);
  559. w.setNonce_str(PayWxUtil.getNonceStr());// 随机支付串
  560. w.setOut_trade_no(book.getOrderNum());
  561. w.setTrade_type("JSAPI");
  562. params = new HashMap<String, String>();
  563. params.put("appid", w.getAppid());
  564. params.put("mch_id", w.getMch_id());
  565. params.put("out_trade_no", w.getOut_trade_no());
  566. params.put("nonce_str", w.getNonce_str());
  567. w.setSign(PayWxUtil.getSign(params, WeiXinUtil.key));
  568. params.put("sign", w.getSign());
  569. String retXml = JaxbUtil.getRequestXml(params);
  570. String msg = HttpUtils.post("https://api.mch.weixin.qq.com/pay/refundquery", retXml);
  571. if (msg.indexOf("<refund_status_0><![CDATA[SUCCESS]]></refund_status_0>")>0) {
  572. // 退款成功,将数据写入本地数据库
  573. book.setRefundTime(DateUtil.parseDateToStr(new Date(),DateUtil.Time_Formatter_Second));
  574. book.setRefundAmount(book.getHouseTotalPrice());
  575. book.setUpdateTime(DateUtil.parseDateToStr(new Date(),DateUtil.Time_Formatter_Second));
  576. book.setOrderStatus(Func.parseStr(PayEnum.getKeyByValue(book.getRemake()))); // 将走微信前的标识,写入回调函数
  577. bookService.updateBooking(book);
  578. // 发送成功消息给商家和用户
  579. AdminManager adminManager = adminManagerService.getById(Func.parseInt(book.getHotelManagerId()));
  580. Users users = userService.queryByUserId(book.getCreateUserid());
  581. String sendMsg = book.getRemake();
  582. // 推给用户(需求确定,用户点取消退款以后[标识订单状态已取消]只发商家,不发用户。 商家点拒单以后[标识订单状态已退单]只发用户不发商家)
  583. int status = Func.parseInt(book.getOrderStatus());
  584. if (status == PayEnum.已退单.getNum()){
  585. Message.send(users.getOpenid(),book.getOrderNum(),book.getUserName(),sendMsg,book.getCreateTime());
  586. }
  587. // 推给商家
  588. String live_end = book.getOrderStartTime().substring(0,10) +"~"+ book.getOrderEndTime().substring(0,10);
  589. String hotelName = Func.checkNull(book.getHotelName()) ? book.getHotelName() : book.getHouseName();
  590. if (status == PayEnum.已取消.getNum()) {
  591. Message2.send(adminManager.getOpenid(), book.getOrderNum(), book.getHouseName(), live_end, book.getUserName(), hotelName, Func.parseStr(book.getId()));
  592. }
  593. }
  594. }
  595. String returnMsg = "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
  596. HttpServletResponse response = ServletActionContext.getResponse();
  597. response.setContentType("text/html;charset=utf-8");
  598. PrintWriter out = response.getWriter();
  599. out.println(returnMsg);
  600. out.flush();
  601. out.close();
  602. return null;
  603. }
  604. /**
  605. * bookingId 订单id
  606. * 删除订单功能(假删除)
  607. *
  608. * @return
  609. */
  610. public String delBooking() {
  611. if (Func.checkNull(getBookingId()))
  612. return null;
  613. JSONObject jsonObject = new JSONObject();
  614. String mess = bookService.delBooking(getBookingId());
  615. if (!Func.checkNull(mess)) {
  616. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  617. jsonObject.put(B.message, mess);
  618. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  619. return null;
  620. }
  621. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  622. jsonObject.put(B.message, ResultStatusCode.OK.getMsg());
  623. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  624. return null;
  625. }
  626. /**
  627. * 验证是否有房间
  628. * houseId, 房型id
  629. * startTime, 开始时间
  630. * endTime 结束时间
  631. *
  632. * @return
  633. */
  634. public String varificationHouse() {
  635. JSONObject jsonObject = new JSONObject();
  636. if (Func.checkNull(houseId) || Func.checkNull(startTime) || Func.checkNull(endTime)) {
  637. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  638. jsonObject.put(B.message, ResultStatusCode.BAD_REQUEST.getMsg());
  639. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  640. return null;
  641. }
  642. String backMessage = appBookService.varificationHouse(houseId, startTime, endTime);
  643. if (!Func.checkNull(backMessage)) {
  644. jsonObject.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  645. jsonObject.put(B.message, backMessage);
  646. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  647. return null;
  648. }
  649. jsonObject.put(B.code, ResultStatusCode.OK.getStatus());
  650. jsonObject.put(B.message, OrderEnum.有空房.toString());
  651. ResponseUtil.writeJson(ServletActionContext.getResponse(), jsonObject.toString());
  652. return null;
  653. }
  654. /**
  655. * open_id
  656. * bookingId
  657. * 用户支付操作
  658. *
  659. * @return
  660. */
  661. public String pay() {
  662. JSONObject resultjson = new JSONObject();
  663. if (Func.checkNull(this.open_id) || Func.checkNull(this.bookingId)) {
  664. resultjson.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  665. resultjson.put(B.message, ResultStatusCode.BAD_REQUEST.getMsg());
  666. ResponseUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  667. return null;
  668. }
  669. Users users = userService.queryByOpenid(open_id); // 用户信息
  670. Booking booking = bookService.getById(Func.parseInt(bookingId)); // 订单信息
  671. if (users == null || booking == null || booking.getOrderStatus().equals(Func.parseStr(PayEnum.支付超时.getNum()))) {
  672. resultjson.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  673. resultjson.put(B.message, ResultStatusCode.BAD_REQUEST.getMsg());
  674. ResponseUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  675. return null;
  676. }
  677. try {
  678. // 支付费用
  679. double totalPrice = booking.getHouseTotalPrice() ;
  680. int totalfee = Func.parseInt(totalPrice * 100);
  681. WechatUnifiedOrder w = new WechatUnifiedOrder();
  682. w.setAppid(WeiXinUtil.appid_c);
  683. w.setAttach("chuanghai");
  684. w.setBody("chuanghai");
  685. w.setMch_id(WeiXinUtil.account);
  686. w.setNonce_str(PayWxUtil.getNonceStr());// 随机支付串
  687. w.setNotify_url(WeiXinUtil.ip_h + "/abkpayResulet.action");// 支付结果回调地址
  688. w.setOpenid(this.open_id);
  689. String orderNo = booking.getOrderNum(); // 订单编号
  690. w.setOut_trade_no(orderNo);
  691. w.setSpbill_create_ip(WeiXinUtil.ip);
  692. w.setTotal_fee(totalfee);
  693. w.setTrade_type("JSAPI");
  694. Map<String, String> params = new HashMap<String, String>();
  695. params.put("attach", w.getAttach());
  696. params.put("appid", w.getAppid());
  697. params.put("mch_id", w.getMch_id());
  698. params.put("nonce_str", w.getNonce_str());
  699. params.put("body", w.getBody());
  700. params.put("out_trade_no", w.getOut_trade_no());
  701. params.put("total_fee", Func.parseStr(w.getTotal_fee()));
  702. params.put("spbill_create_ip", w.getSpbill_create_ip());
  703. params.put("notify_url", w.getNotify_url());
  704. params.put("trade_type", w.getTrade_type());
  705. params.put("openid", w.getOpenid());
  706. w.setSign(PayWxUtil.getSign(params, WeiXinUtil.key));
  707. params.put("sign", w.getSign());
  708. String retXml = JaxbUtil.getRequestXml(params);
  709. String msg = HttpUtils.post("https://api.mch.weixin.qq.com/pay/unifiedorder", retXml);
  710. System.out.println(msg);
  711. // 支付失败
  712. if (msg.indexOf("FAIL") > -1) {
  713. resultjson.put("code", "205");
  714. resultjson.put("message", "支付异常205");
  715. ResUtil.write(resultjson, ServletActionContext.getResponse());
  716. return null;
  717. }
  718. JaxbUtil requestBinder = new JaxbUtil(TongYiReturn.class, JaxbUtil.CollectionWrapper.class);
  719. TongYiReturn to = requestBinder.fromXml(msg);
  720. // 支付成功
  721. if (to.getReturn_code().equals("SUCCESS") && to.getResult_code().equals("SUCCESS")) {
  722. EndPay pay = new EndPay();
  723. pay.setAppId(WeiXinUtil.appid_c);
  724. pay.setSignType("MD5");
  725. pay.setTimeStamp(System.currentTimeMillis() / 1000 + "");
  726. pay.setPrepay_id(to.getPrepay_id());
  727. pay.setNonceStr(PayWxUtil.getNonceStr());
  728. Map<String, String> requestMap = new HashMap<String, String>();
  729. requestMap.put("appId", pay.getAppId());
  730. requestMap.put("timeStamp", pay.getTimeStamp());
  731. requestMap.put("nonceStr", pay.getNonceStr());
  732. requestMap.put("package", "prepay_id=" + pay.getPrepay_id());
  733. requestMap.put("signType", "MD5");
  734. pay.setPaySign(PayWxUtil.getSign(requestMap, WeiXinUtil.key));
  735. // 保存支付信息
  736. booking.setUpdateTime(DateUtil.getFormatPaternDate(new Date()));
  737. booking.setOrderStatus(Func.parseStr(PayEnum.待支付.getNum()));
  738. booking.setPayTime(DateUtil.getFormatPaternDate(new Date()));
  739. booking.setPayAccount(totalPrice);
  740. booking.setPayWay(OrderEnum.微信支付.toString());
  741. bookService.updateBooking(booking);
  742. resultjson.put(B.code, ResultStatusCode.OK.getStatus());
  743. resultjson.put(B.message, "返回成功");
  744. resultjson.put(B.data, pay);
  745. ResponseUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  746. }
  747. } catch (Exception e) {
  748. resultjson.put(B.code, ResultStatusCode.BAD_REQUEST.getStatus());
  749. resultjson.put(B.message, e.getMessage());
  750. ResponseUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  751. }
  752. return null;
  753. }
  754. /**
  755. * 支付成功后回调,推送消息给商家
  756. *
  757. */
  758. public String payResulet(){
  759. System.out.println("进入支付回调====");
  760. JSONObject resultjson = new JSONObject();
  761. try{
  762. BufferedReader reader = null;// BufferedReader 字符输入流
  763. reader = request.getReader();
  764. String line = "";
  765. String xmlString = null;
  766. StringBuilder inputString = new StringBuilder();
  767. while ((line = reader.readLine()) != null) {
  768. inputString.append(line);
  769. }
  770. xmlString = inputString.toString();
  771. request.getReader().close();
  772. JaxbUtil requestBinder = new JaxbUtil(PayResult.class, PayResult.class);
  773. PayResult result = requestBinder.fromXml(xmlString);// Xml到Java,用fromXML()方法
  774. String order_num = result.getOut_trade_no();
  775. System.out.println("支付成功回调,订单号:"+order_num);
  776. Booking booking = bookService.queryByOrder(order_num);
  777. // 支付成功
  778. if (result.getResult_code().equals("SUCCESS") && booking!=null && ("1").equals(booking.getOrderStatus())) {
  779. // 保存支付信息
  780. booking.setUpdateTime(DateUtil.getFormatPaternDate(new Date()));
  781. booking.setOrderStatus(Func.parseStr(PayEnum.已支付.getNum()));
  782. booking.setPayTime(DateUtil.getFormatPaternDate(new Date()));
  783. booking.setPayWay(OrderEnum.微信支付.toString());
  784. // 进行业务判断,如果是商家设定了自动接单,则支付状态直接变为待入住 接单设置(1自动接单 2手动接单)
  785. if ("1".equals(booking.getHotelIsOrder()))
  786. {
  787. // 自动接单,订单状态修改为待入住
  788. booking.setOrderStatus(Func.parseStr(PayEnum.待入住.getNum()));
  789. String userId = booking.getCreateUserid();
  790. Users users = userService.queryByUserId(userId);
  791. String mess = "您已成功订房,订单号:"+order_num;
  792. Message.send(users.getOpenid(),order_num, users.getUser_name(),mess, booking.getPayTime());
  793. }
  794. // 手动接单,发消息给商家
  795. AdminManager adminManager = adminManagerService.getById(Func.parseInt(booking.getHotelManagerId()));
  796. String live_end = booking.getOrderStartTime().substring(0,10) +"~"+ booking.getOrderEndTime().substring(0,10);
  797. String hotelName = booking.getHotelName();
  798. if (Func.checkNull(booking.getHotelName()))
  799. {
  800. hotelName = booking.getHouseName();
  801. }
  802. System.out.println(adminManager.getOpenid()+"==="+order_num +"==="+booking.getHouseName()+"==="+live_end+"==="+booking.getUserName()+"==="+hotelName);
  803. Message2.send(adminManager.getOpenid(),order_num,booking.getHouseName(),live_end,booking.getUserName(),hotelName, Func.parseStr(booking.getId()));
  804. int m = bookService.updateBooking(booking);
  805. if (m>0){
  806. String returnMsg = "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
  807. HttpServletResponse response = ServletActionContext.getResponse();
  808. response.setContentType("text/html;charset=utf-8");
  809. PrintWriter out = response.getWriter();
  810. out.println(returnMsg);
  811. out.flush();
  812. out.close(); // 发送成功消息给商家
  813. }
  814. return null;
  815. }
  816. } catch (Exception e){
  817. resultjson.put("message", "支付失败");
  818. resultjson.put("code", 205);
  819. ResUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  820. return null;
  821. }
  822. resultjson.put("message", "支付失败");
  823. resultjson.put("code", 205);
  824. ResUtil.writeJson(ServletActionContext.getResponse(), resultjson.toString());
  825. return null;
  826. }
  827. public String getOpen_id() {
  828. return open_id;
  829. }
  830. public void setOpen_id(String open_id) {
  831. this.open_id = open_id;
  832. }
  833. }