PayController.java 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757
  1. package com.platform.yijia.controller;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.alibaba.fastjson.parser.Feature;
  5. import com.google.gson.Gson;
  6. import com.platform.yijia.param.request.*;
  7. import com.platform.yijia.pojo.AppUserInfo;
  8. import com.platform.yijia.pojo.CustomerManage;
  9. import com.platform.yijia.pojo.PayOrder;
  10. import com.platform.yijia.service.AppUserInfoService;
  11. import com.platform.yijia.service.CustomerGradeServices;
  12. import com.platform.yijia.service.PayOrderService;
  13. import com.platform.yijia.service.StationOilGunService;
  14. import com.platform.yijia.utils.*;
  15. import org.apache.commons.lang3.StringUtils;
  16. import org.slf4j.Logger;
  17. import org.slf4j.LoggerFactory;
  18. import org.springframework.stereotype.Controller;
  19. import org.springframework.web.bind.annotation.*;
  20. import javax.annotation.Resource;
  21. import java.math.BigDecimal;
  22. import java.text.ParseException;
  23. import java.text.SimpleDateFormat;
  24. import java.util.*;
  25. @Controller
  26. @RequestMapping("/api")
  27. public class PayController {
  28. private static Logger logger =(Logger) LoggerFactory.getLogger(PayController.class);
  29. @Resource
  30. private PayOrderService payOrderService;
  31. @Resource
  32. private AppUserInfoService appUserInfoService;
  33. @Resource
  34. private StationOilGunService stationOilGunService;
  35. @Resource
  36. private CustomerGradeServices customerGradeServices;
  37. /***
  38. * 微信子商户支付接口
  39. * @param weChatPaySetRequest
  40. * @return
  41. */
  42. @RequestMapping(value = "/weChatPaySet", consumes = "application/json", method = RequestMethod.POST)
  43. @ResponseBody
  44. public String weChatPaySet(@RequestBody WeChatPaySetRequest weChatPaySetRequest){
  45. Gson gson = new Gson();
  46. ResultData resultData = null; //返回结果
  47. try {
  48. String type = weChatPaySetRequest.getType(); //获取配置类型
  49. JSONObject reqData = new JSONObject(); //微信子商户支付参数配置
  50. reqData.put("mno", weChatPaySetRequest.getMno()); //商编
  51. reqData.put("subMchIdsubMchId", weChatPaySetRequest.getSubMchIdsubMchId()); //获取微信子商号
  52. if(type != null && type !=""){
  53. reqData.put("type", type);
  54. //根据类型设置必传参数
  55. switch (type){
  56. case "01": //支付Appid
  57. reqData.put("accountType", weChatPaySetRequest.getAccountType()); // 支付Appid类型 配置类型为01时必传
  58. reqData.put("subAppid", weChatPaySetRequest.getSubAppid()); // 支付Appid 配置类型为01,02时必传
  59. break;
  60. case "02": //关注Appid
  61. reqData.put("subAppid", weChatPaySetRequest.getSubAppid()); // 支付Appid 配置类型为01,02时必传
  62. reqData.put("subscribeAppid", weChatPaySetRequest.getSubscribeAppid()); // 推荐关注公众号Appid 配置类型为02时与推荐关注 小程序Appid二选一
  63. reqData.put("receiptAppid", weChatPaySetRequest.getReceiptAppid()); // 推荐关注小程序Appid 配置类型为02时与推荐关注 公众号Appid二选一
  64. break;
  65. case "03": //jsapi授权目录
  66. reqData.put("jsapiPath", weChatPaySetRequest.getJsapiPath()); // jsapi授权目录 配置类型为03时必传
  67. break;
  68. }
  69. }
  70. String sxfPay = SXFPaySign.getSXFPay(reqData); //封装传参信息,增加公共信息,增加业务信息
  71. logger.debug("参数信息:"+ sxfPay);
  72. System.out.println("req:" + sxfPay);
  73. //此处不要改变reqData里面值的顺序用LinkedHashMap
  74. HashMap reqMap = JSON.parseObject(sxfPay, LinkedHashMap.class, Feature.OrderedField);
  75. //组装加密串
  76. String signContent = RSASignature.getOrderContent(reqMap);
  77. System.out.println("拼接后的参数:" + signContent);
  78. logger.debug("拼接后的参数:"+signContent);
  79. //sign
  80. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  81. reqMap.put("sign", sign);
  82. String reqStr = JSON.toJSONString(reqMap);
  83. System.out.println("请求参数:" + reqMap);
  84. System.out.println("请求参数:" + reqStr);
  85. //String url = "https://openapi-test.tianquetech.com/merchant/weChatPaySet/addConf"; //测试环境
  86. String url = "https://openapi.tianquetech.com/merchant/weChatPaySet/addConf"; //生产环境
  87. //访问第三方接口
  88. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  89. System.out.println("返回信息:" + resultJson);
  90. // logger.debug("返回信息:"+resultJson);
  91. //不要对reqData排序 所以用LinkedHashMap
  92. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  93. if ("0000".equals(result.get("code"))) {
  94. //验签
  95. String signResult = result.get("sign").toString();
  96. result.remove("sign");
  97. String resultStr = RSASignature.getOrderContent(result);
  98. System.out.println(resultStr);
  99. //sign
  100. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  101. System.out.println("resultSign:" + resultSign);
  102. //组装加密串
  103. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  104. System.out.println("===================验签成功==============");
  105. }
  106. }
  107. resultData=ResultData.success(result);
  108. } catch (Exception e) {
  109. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"支付失败");
  110. e.printStackTrace();
  111. }
  112. return gson.toJson(resultData);
  113. }
  114. /**
  115. * 支付接口,前台上传支付信息,支付数据落地生产订单,调用随行付支付接口
  116. * @param
  117. * @return
  118. */
  119. @RequestMapping(value = "/getJhPayInfo", consumes = "application/json", method = RequestMethod.POST)
  120. @ResponseBody
  121. public String getJhPayInfo(@RequestBody PayInfoRequest payInfoRequest){
  122. Gson gson =new Gson();
  123. ResultData resultData =null;
  124. //String token=payInfoRequest.getToken();//token
  125. String openId = payInfoRequest.getOpenId(); //用户openId
  126. String userType=payInfoRequest.getUserType();//用户登录类型 1 公众号。2 小程序
  127. String mno=payInfoRequest.getMno();//获取商户号
  128. Integer orderId =payInfoRequest.getOrderId();
  129. //根据token 和登录类型 身份验证
  130. AppUserInfo appUserInfo =new AppUserInfo();
  131. //订单类型 是小程序还是公众号
  132. appUserInfo.setUserType(userType);
  133. if(userType.equals("1")){
  134. //1 是公众号
  135. appUserInfo.setBlogOpenid(openId);
  136. }else if(userType.equals("2")){
  137. //2是小程序
  138. appUserInfo.setMinaOpenid(openId);
  139. }
  140. List<AppUserInfo> appUserInfoList =appUserInfoService.Authentication(appUserInfo);
  141. if(appUserInfoList!=null&&appUserInfoList.size()==1){
  142. //调用聚合支付
  143. try{
  144. //根据订单号查询订单信息
  145. PayOrder payOrder=payOrderService.searchPayOrder(orderId);
  146. if(payOrder!=null){
  147. //将业务参数存放在 JSON 对象中
  148. JSONObject reqData = new JSONObject();
  149. reqData.put("ordNo", payOrder.getOrderNo()); //商户订单号
  150. reqData.put("mno", mno); //商户编号
  151. //reqData.put("subMechId", ""); //子商户号
  152. reqData.put("amt", payOrder.getAmt()); //订单总金额
  153. //reqData.put("amt", "0.01");
  154. //reqData.put("discountAmt", ""); //参与优惠金额
  155. //reqData.put("unDiscountAmt", ""); //不参与优惠金额
  156. reqData.put("payType", "WECHAT"); //支付渠道
  157. if(userType.equals("1")){
  158. //1 是公众号
  159. reqData.put("payWay", "02"); //支付方式 02 公众号/服 务窗/js支付 03 小程序
  160. reqData.put("userId", appUserInfoList.get(0).getBlogOpenid()); //用户号 微信:openid; 支付宝:userid;银联:userid;微信&支付宝必传,银联js为非必传
  161. }else if(userType.equals("2")){
  162. //2是小程序
  163. reqData.put("payWay", "03"); //支付方式 02 公众号/服 务窗/js支付 03 小程序
  164. reqData.put("userId", appUserInfoList.get(0).getMinaOpenid()); //用户号 微信:openid; 支付宝:userid;银联:userid;微信&支付宝必传,银联js为非必传
  165. }
  166. //reqData.put("timeExpire", "10"); //订单失效时间, 以分钟为单位
  167. //reqData.put("limitPay", "00"); //限制卡类型: 00-全部 01-限定不能使 用信用卡支付 默认值 00
  168. reqData.put("subject", "聚合支付测试"); //订单标题
  169. //reqData.put("hbFqNum", "6"); //花呗分期数,仅可上送 6 或 12
  170. reqData.put("tradeSource", "01"); //交易来源 01服务商,02收银台,03硬件
  171. reqData.put("trmIp", "172.16.2.1");//商家ip地址
  172. // reqData.put("customerIp", ""); //持卡人ip地址,银联js支付时必传
  173. //reqData.put("subAppid", "wx24210004370ec43b"); //微信子公众号
  174. //reqData.put("outFrontUrl", ""); //js 支付,前台 成功通知地址
  175. //reqData.put("outFrontFailUrl", ""); //js 支付,前台 事变通知地址
  176. reqData.put("notifyUrl", "https://www.huijy.net/api/getCallback"); //回调地址
  177. //reqData.put("needReceipt", "00"); //电子发票功能 微信开具电子 发票使用
  178. //reqData.put("ledgerAccountFlag", "00"); //是否做分账 分账交易使 用;00:做; 01:不做;不传默认为不做分账
  179. //reqData.put("ledgerAccountEffectTime", "00"); //分账有效时间 单位为天;是 否做分账选择 00 时该字段必传
  180. // reqData.put("ruleId", "00"); //同 步 分 账 规 则 id
  181. // reqData.put("fusruleId", "00"); //同步分账规则
  182. //reqData.put("ylTrmNo", ""); //银联终端号
  183. //reqData.put("terminalId", ""); //TQ机具编号
  184. //reqData.put("deviceNo ", "1111"); //设备号
  185. // reqData.put("identityFlag", ""); //是否是实名支付
  186. // reqData.put("buyerIdType", "IDCARD"); //证件类型
  187. // reqData.put("buyerIdNo", "410523198701054018"); //证件号
  188. // reqData.put("buyerName", "张三"); //买家姓名
  189. // reqData.put("mobileNum", ""); //手机号
  190. // reqData.put("extend", ""); //备用
  191. String req= SXFPaySign.getSXFPay(reqData);
  192. logger.debug("参数信息:"+req);
  193. System.out.println("req:" + req);
  194. //此处不要改变reqData里面值的顺序用LinkedHashMap
  195. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  196. //组装加密串
  197. String signContent = RSASignature.getOrderContent(reqMap);
  198. System.out.println("拼接后的参数:" + signContent);
  199. logger.debug("拼接后的参数:"+signContent);
  200. //sign
  201. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  202. System.out.println("============签名:" + sign);
  203. reqMap.put("sign", sign);
  204. String reqStr = JSON.toJSONString(reqMap);
  205. System.out.println("请求参数:" + reqMap);
  206. System.out.println("请求参数:" + reqStr);
  207. //调用第三方接口地址
  208. //String url = "https://openapi-test.tianquetech.com/order/jsapiScan";//测试地址
  209. String url = "https://openapi.suixingpay.com/order/jsapiScan";//生产地址
  210. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  211. System.out.println("返回信息:" + resultJson);
  212. // logger.debug("返回信息:"+resultJson);
  213. //不要对reqData排序 所以用LinkedHashMap
  214. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  215. if ("0000".equals(result.get("code"))) {
  216. //验签
  217. String signResult = result.get("sign").toString();
  218. result.remove("sign");
  219. String resultStr = RSASignature.getOrderContent(result);
  220. System.out.println(resultStr);
  221. //sign
  222. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  223. System.out.println("resultSign:" + resultSign);
  224. //组装加密串
  225. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  226. System.out.println("===================验签成功==============");
  227. }
  228. }
  229. resultData=ResultData.success(result);
  230. }else {
  231. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"未查询到订单");
  232. }
  233. }catch (Exception e){
  234. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"订单支付失败");
  235. e.printStackTrace();
  236. }
  237. }else{
  238. //返回失败支付失败信息
  239. resultData=ResultData.error(CodeMsg.USER_NOT_EXSIST);
  240. }
  241. return gson.toJson(resultData);
  242. }
  243. /**
  244. * 验证商户信息查询
  245. */
  246. @RequestMapping(value = "/getJhPayMnoInfo", method = RequestMethod.GET)
  247. @ResponseBody
  248. public String getJhPayMnoInfo(@RequestParam String mno){
  249. try {
  250. JSONObject reqData = new JSONObject();
  251. reqData.put("mno", mno); //商户编号
  252. String req = SXFPaySign.getSXFPay(reqData);
  253. logger.debug("参数信息:" + req);
  254. System.out.println("req:" + req);
  255. //此处不要改变reqData里面值的顺序用LinkedHashMap
  256. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  257. //组装加密串
  258. String signContent = RSASignature.getOrderContent(reqMap);
  259. System.out.println("拼接后的参数:" + signContent);
  260. logger.debug("拼接后的参数:" + signContent);
  261. //sign
  262. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  263. System.out.println("============签名:" + sign);
  264. reqMap.put("sign", sign);
  265. String reqStr = JSON.toJSONString(reqMap);
  266. System.out.println("请求参数:" + reqMap);
  267. System.out.println("请求参数:" + reqStr);
  268. //调用第三方接口地址
  269. //String url = "https://openapi-test.tianquetech.com/merchant/merchantInfoQuery";//测试地址
  270. String url = "https://openapi.tianquetech.com/merchant/merchantInfoQuery";//生产地址
  271. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  272. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  273. if ("0000".equals(result.get("code"))) {
  274. // //验签
  275. // String signResult = result.get("sign").toString();
  276. // result.remove("sign");
  277. // String resultStr = RSASignature.getOrderContent(result);
  278. // System.out.println(resultStr);
  279. // //sign
  280. // String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  281. // System.out.println("resultSign:" + resultSign);
  282. // //组装加密串
  283. // if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  284. // System.out.println("===================验签成功==============");
  285. // }
  286. }
  287. }catch (Exception e){
  288. e.printStackTrace();
  289. }
  290. return "";
  291. }
  292. /**
  293. * 关单接口
  294. */
  295. @RequestMapping(value = "/getPayOrderClose", consumes = "application/json", method = RequestMethod.POST)
  296. @ResponseBody
  297. public String getPayOrderClose(@RequestBody PayCloseRequestParamter payCloseRequestParamter) {
  298. String results="";
  299. Gson gson =new Gson();
  300. String mno=payCloseRequestParamter.getMno();
  301. String origOrderNo=payCloseRequestParamter.getOrigOrderNo();
  302. String origUuid=payCloseRequestParamter.getOrigUuid();
  303. String token=payCloseRequestParamter.getToken();
  304. String userType=payCloseRequestParamter.getUserType();
  305. boolean flag =appUserInfoService.selectAppUserInfo(token,userType);
  306. ResultData resultData =null;
  307. if(flag){
  308. try {
  309. JSONObject reqData = new JSONObject();
  310. reqData.put("mno",mno); //商户编号
  311. reqData.put("origOrderNo",origOrderNo);//系统商户订单号
  312. reqData.put("origUuid", origUuid);//随行付订单号
  313. String req= SXFPaySign.getSXFPay(reqData);
  314. //此处不要改变reqData里面值的顺序用LinkedHashMap
  315. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  316. //组装加密串
  317. String signContent = RSASignature.getOrderContent(reqMap);
  318. System.out.println("拼接后的参数:" + signContent);
  319. //sign
  320. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  321. System.out.println("============签名:" + sign);
  322. reqMap.put("sign", sign);
  323. String reqStr = JSON.toJSONString(reqMap);
  324. System.out.println("请求参数:" + reqMap);
  325. System.out.println("请求参数:" + reqStr);
  326. //调用第三方接口地址
  327. // String url = "https://openapi-test.tianquetech.com/query/close";//测试地址
  328. String url = "https://openapi.tianquetech.com/query/close";//生产地址
  329. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  330. System.out.println("返回信息:" + resultJson);
  331. //不要对reqData排序 所以用LinkedHashMap
  332. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  333. if ("0000".equals(result.get("code"))) {
  334. //验签
  335. String signResult = result.get("sign").toString();
  336. result.remove("sign");
  337. String resultStr = RSASignature.getOrderContent(result);
  338. System.out.println(resultStr);
  339. //sign
  340. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent,SXFPaySign.privateKey));
  341. System.out.println("resultSign:" + resultSign);
  342. //组装加密串
  343. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  344. System.out.println("===================验签成功==============");
  345. }
  346. }
  347. resultData=ResultData.success(result);
  348. }catch (Exception e){
  349. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"关闭订单失败");
  350. e.printStackTrace();
  351. }
  352. }else{
  353. resultData=ResultData.error(CodeMsg.USER_NOT_EXSIST);
  354. }
  355. return gson.toJson(resultData);
  356. }
  357. /**
  358. * 异步回调通知
  359. */
  360. @RequestMapping(value = "/getCallback", consumes = "application/json", method = RequestMethod.POST)
  361. @ResponseBody
  362. public void getCallback(@RequestBody JSONObject request){
  363. logger.info("-------------------------------回调开始----------------------------------------------");
  364. logger.info("回调返回过来的参数"+request);
  365. logger.info("ordNo信息:" + request.get("ordNo").toString());
  366. logger.info("sign信息:" + request.get("sign").toString());
  367. Gson gson =new Gson();
  368. String sxfUuid=request.get("sxfUuid").toString(); //随行付落单号
  369. String payWay=request.get("payWay").toString(); //随行付交易方式
  370. String payTime=request.get("payTime").toString(); //随行付交易时间
  371. String uuid=request.get("uuid").toString(); //随行付交易流水号
  372. String mno=request.get("mno").toString();//发起交易的商户编号
  373. String ordNo=request.get("ordNo").toString();//商户生成的订单号
  374. String amt=request.get("amt").toString();//金额
  375. String buyerId=request.get("buyerId").toString();//用户登录
  376. String transactionId=request.get("transactionId").toString();//用户登录
  377. String drType=request.get("drType").toString();//借贷记标识 1-借,2-贷,3-其他
  378. String payType=request.get("payType").toString();//对订单的描述,取值范围:WECHAT:微信,ALIPAY:支付宝,UNIONPAY:
  379. String payBank=request.get("payBank").toString();//付款银行银行编码,例如 ICBC
  380. String pointAmount=request.get("pointAmount").toString();//代金券金额
  381. String totalOffstAmt=request.get("totalOffstAmt").toString();//消 费 者 付 款金额
  382. String settleAmt=request.get("settleAmt").toString();//商家入账金额
  383. String timeStamp=request.get("timeStamp").toString();//响应时间
  384. String sign=request.get("sign").toString();//签名
  385. String bizCode=request.get("bizCode").toString();//业务返回码
  386. String bizMsg=request.get("bizMsg").toString();//业 务 返 回 信息
  387. String openid=request.get("openid").toString();//微 信 或 支 付宝身份id()opendid userid
  388. String channelId=request.get("channelId").toString();//渠道商户号
  389. String subMechId=request.get("subMechId").toString();//子商户号
  390. String finishTime=request.get("finishTime").toString();//交易完成时间
  391. String clearDt=request.get("clearDt").toString();
  392. String settlementBatchNo=request.get("settlementBatchNo").toString();
  393. //String origOrdNo=request.get("origOrdNo").toString();//反交易退款异步通知
  394. //String origUuid=request.get("origUuid").toString();//token
  395. //String scene=request.get("scene").toString();//用户登录
  396. //String buyerAccount=request.get("buyerAccount").toString();//
  397. //String realRefundAmount=request.get("realRefundAmount").toString();//商家出账金额
  398. //String recFeeAmt=request.get("recFeeAmt").toString();//交易手续费
  399. //String recFeeRate=request.get("recFeeRate").toString();//交易手续费率
  400. //String refBuyerAmt=request.get("refBuyerAmt").toString();//消 费 者 到 账金额
  401. //String extend = extend=request.get("extend").toString();//备用
  402. //将业务参数存放在 JSON 对象中
  403. JSONObject reqData = new JSONObject();
  404. reqData.put("sxfUuid",sxfUuid);
  405. reqData.put("payWay",payWay);
  406. reqData.put("payTime",payTime);
  407. reqData.put("uuid",uuid);
  408. reqData.put("mno",mno);
  409. reqData.put("ordNo",ordNo);
  410. reqData.put("amt",amt);
  411. reqData.put("buyerId",buyerId);
  412. reqData.put("transactionId",transactionId);
  413. reqData.put("drType",drType);
  414. reqData.put("payType",payType);
  415. reqData.put("payBank",payBank);
  416. reqData.put("pointAmount",pointAmount);
  417. reqData.put("totalOffstAmt",totalOffstAmt);
  418. reqData.put("settleAmt",settleAmt);
  419. reqData.put("timeStamp",timeStamp);
  420. reqData.put("bizCode",bizCode);
  421. reqData.put("bizMsg",bizMsg);
  422. reqData.put("openid",openid);
  423. reqData.put("channelId",channelId);
  424. reqData.put("subMechId",subMechId);
  425. reqData.put("finishTime",finishTime);
  426. reqData.put("clearDt",clearDt);
  427. reqData.put("settlementBatchNo",settlementBatchNo);
  428. //reqData.put("realRefundAmount",realRefundAmount);
  429. //reqData.put("recFeeAmt",recFeeAmt);
  430. //reqData.put("recFeeRate",recFeeRate);
  431. //reqData.put("buyerAccount",buyerAccount);
  432. //reqData.put("origOrdNo",origOrdNo);
  433. //reqData.put("origUuid",origUuid);
  434. //reqData.put("scene",scene);
  435. //reqData.put("refBuyerAmt",refBuyerAmt);
  436. //reqData.put("extend",extend);
  437. //根据回调信息,先进行验签,验签后修改状态
  438. logger.info("打印参数信息"+gson.toJson(reqData));
  439. //不要对reqData排序 所以用LinkedHashMap
  440. HashMap<String, Object> result = JSON.parseObject(gson.toJson(reqData), LinkedHashMap.class, Feature.OrderedField);
  441. //验签
  442. String resultStr = RSASignature.getOrderContent(result);
  443. JSONObject req = new JSONObject();
  444. System.out.println(resultStr);
  445. if (RSASignature.doCheck(resultStr, sign, SXFPaySign.sxfPublic)) {
  446. logger.info("验签成功");
  447. //验签成功,修改订单状态
  448. List<PayOrder> list = payOrderService.getPayOrderList(ordNo);
  449. logger.info("根据订单号,查询订单"+gson.toJson(list));
  450. if (list != null && list.size() == 1) {
  451. String status = list.get(0).getStatus();
  452. //状态为未支付 0 修改状态为1已支付
  453. if (status.equals("0")) {
  454. PayOrder payOrder = new PayOrder();
  455. payOrder.setOrderNo(ordNo);
  456. payOrder.setStatus("1");
  457. payOrder.setPayDate(new Date()); //支付时间
  458. payOrder.setReceivedAmt(Double.valueOf(settleAmt)); //settleAmt商家入账金额
  459. //修改订单状态
  460. int count = payOrderService.getUpdatePayOrder(payOrder);
  461. if(count == 1){
  462. req.put("code","success");
  463. req.put("msg","修改订单状态成功");
  464. logger.info(req.toString());
  465. //将用户消费的信息插入顾客表: 以手机号 油品名称 油站id为条件插入且存入 加油升数、实收金额、油站名称 根据订单号查询用户手机号
  466. Map<String, Object> infoMap = payOrderService.getOrderInfoAndUserInfoByOrderNo(payOrder); //获取该订单手机号、加油升数、实收金额、油站名称
  467. //手机号必须有
  468. if(infoMap != null && infoMap.containsKey("mobilePhone") && infoMap.get("mobilePhone") !=null ){
  469. //存放客户信息
  470. CustomerManage customerManage = new CustomerManage();
  471. //存放查询用户信息
  472. AppUserInfo appUserInfo = new AppUserInfo();
  473. appUserInfo.setMobilePhone(infoMap.get("mobilePhone").toString());
  474. //从客户信息表查询数据用于插入客户表 使用List原因:app_user_info存在小程序和公众号两种信息
  475. List<AppUserInfo> appUserInfoList = payOrderService.getUserInfoByOpenId(appUserInfo);
  476. Date blogRegTime = null; //公众号注册时间
  477. Date minaRegTime = null; //小程序注册时间
  478. if(appUserInfoList != null && appUserInfoList.size() >0){
  479. for(AppUserInfo u : appUserInfoList){
  480. //向客户表插入小程序和公众号的openId 用户表ID 用户手机号 注册时间
  481. switch (u.getUserType()){
  482. case "1":
  483. customerManage.setBlogOpenid(u.getBlogOpenid());
  484. customerManage.setBlogUserId(u.getUserId());
  485. customerManage.setPhoneNumber(u.getMobilePhone());
  486. customerManage.setCustomerName(u.getBlogNickName());
  487. blogRegTime =u.getRegisteDate();
  488. break;
  489. case "2":
  490. customerManage.setMinaOpenid(u.getMinaOpenid());
  491. customerManage.setMinaUserId(u.getUserId());
  492. customerManage.setPhoneNumber(u.getMobilePhone());
  493. customerManage.setCustomerName(u.getBlogNickName());
  494. minaRegTime = u.getRegisteDate();
  495. break;
  496. }
  497. }
  498. //判断公众号和小程序时间取最早的时间
  499. if(blogRegTime !=null && minaRegTime != null){
  500. if(blogRegTime.compareTo(minaRegTime) >0){
  501. customerManage.setRegtime(minaRegTime);
  502. }else if(blogRegTime.compareTo(minaRegTime) <0){
  503. customerManage.setRegtime(blogRegTime);
  504. }else if(blogRegTime.compareTo(minaRegTime) ==0){
  505. //相等时随便取一个
  506. customerManage.setRegtime(minaRegTime);
  507. }
  508. }else if(blogRegTime == null){
  509. customerManage.setRegtime(minaRegTime);
  510. }else if(minaRegTime == null){
  511. customerManage.setRegtime(blogRegTime);
  512. }
  513. }
  514. customerManage.setStationId(Integer.valueOf(infoMap.get("stationId").toString())); //油站ID
  515. customerManage.setOilName(infoMap.get("oilName").toString()); //油品名称
  516. customerManage.setStationName(infoMap.get("stationName").toString()); //存入油站名称
  517. //已存在用户信息 existCustomer
  518. CustomerManage existCustomer = payOrderService.isExistCustomer(customerManage);
  519. logger.info("查询出客户是否存在数据 null 表示没有" + existCustomer);
  520. //判断该用户是否已存在
  521. if(existCustomer != null){ //存在该用户时更新
  522. //此处if放null处理
  523. if(existCustomer.getAmt() !=null){
  524. //存入金额 累加原来金额
  525. customerManage.setAmt(existCustomer.getAmt().add(BigDecimal.valueOf((Double) infoMap.get("amt"))));
  526. }else {
  527. customerManage.setAmt(BigDecimal.valueOf((Double) infoMap.get("amt")));
  528. }
  529. if(existCustomer.getLiters() !=null){
  530. //存入升数 累加原来升数
  531. customerManage.setLiters(existCustomer.getLiters().add(BigDecimal.valueOf((Double) infoMap.get("orderLiters"))));
  532. }else {
  533. customerManage.setLiters(BigDecimal.valueOf((Double) infoMap.get("orderLiters")));
  534. }
  535. logger.info("存在客户 更新时手机号参数: " + customerManage.getPhoneNumber());
  536. //用户等级设置 说明:每个油站只存在一种优惠方案。 立减满减在另一张表故作次条件判断,如果该油站没有设置优惠方案则不去存会员等级
  537. List<Map> customerGradeInfo = customerGradeServices.getCustomerGradeList(infoMap); //直降
  538. if(customerGradeInfo != null && customerGradeInfo.size() >0){
  539. for (Map m: customerGradeInfo){
  540. if(Double.valueOf(customerManage.getAmt().toString()) >= Double.valueOf(m.get("memberConditStart").toString()) && Double.valueOf(customerManage.getAmt().toString()) < Double.valueOf(m.get("memberConditEnd").toString())){
  541. customerManage.setGrade(m.get("grade").toString()); //存入等级名称
  542. customerManage.setMemberId(m.get("id").toString()); //存入等级ID
  543. }
  544. break;
  545. }
  546. }else {
  547. //立减满减
  548. List<Map> customerMarkertPlanList = customerGradeServices.getCustomerMarkertPlanList(infoMap);
  549. if(customerMarkertPlanList !=null && customerMarkertPlanList.size() >0){
  550. for(Map m: customerMarkertPlanList){
  551. if(Double.valueOf(customerManage.getAmt().toString()) >= Double.valueOf(m.get("discountAmt").toString())){
  552. customerManage.setGrade(m.get("grade").toString()); //存入等级名称
  553. customerManage.setMemberId(m.get("id").toString()); //存入等级ID
  554. }
  555. break;
  556. }
  557. }
  558. }
  559. //存在 更新
  560. payOrderService.updateCustomer(customerManage);
  561. }else{ //该客户不存在时插入
  562. //用户等级设置 说明:每个油站只存在一种优惠方案。立减满减在另一张表故作此条件判断,如果该油站没有设置优惠方案则不去存会员等级
  563. List<Map> customerGradeInfo = customerGradeServices.getCustomerGradeList(infoMap); //直降
  564. if(customerGradeInfo != null && customerGradeInfo.size() >0){
  565. for (Map m: customerGradeInfo){
  566. if(Double.valueOf(infoMap.get("amt").toString()) >= Double.valueOf(m.get("memberConditStart").toString()) && Double.valueOf(infoMap.get("amt").toString()) < Double.valueOf(m.get("memberConditEnd").toString())){
  567. customerManage.setGrade(m.get("grade").toString()); //存入等级名称
  568. customerManage.setMemberId(m.get("id").toString()); //存入等级ID
  569. }
  570. break;
  571. }
  572. }else {
  573. //立减满减
  574. List<Map> customerMarkertPlanList = customerGradeServices.getCustomerMarkertPlanList(infoMap);
  575. if(customerMarkertPlanList !=null && customerMarkertPlanList.size() >0){
  576. for(Map m: customerMarkertPlanList){
  577. if(Double.valueOf(infoMap.get("amt").toString()) >= Double.valueOf(m.get("discountAmt").toString())){
  578. customerManage.setGrade(m.get("grade").toString()); //存入等级名称
  579. customerManage.setMemberId(m.get("id").toString()); //存入等级ID
  580. }
  581. break;
  582. }
  583. }
  584. }
  585. customerManage.setAmt(BigDecimal.valueOf((Double) infoMap.get("amt"))); //存入金额
  586. customerManage.setLiters(BigDecimal.valueOf((Double) infoMap.get("orderLiters"))); //存入升数
  587. //不存在 新增
  588. logger.info("不存在客户 新增时参数: " + customerManage.toString());
  589. payOrderService.insertCustomer(customerManage);
  590. }
  591. //打印机打印小票
  592. String content1;
  593. String content2;
  594. String orderNoP = "";
  595. String createdDateP ="";
  596. String stationNameP ="";
  597. String oilNameP ="";
  598. String orderLitersP ="";
  599. String oilPirceP ="";
  600. String receivableAmtP = "";
  601. String discountAmtP = "";
  602. String amtP = "";
  603. String mobilePhoneP = "";
  604. String payWayP = "";
  605. String sn; //打印机编号
  606. //logger.info("要打印小票的订单信息: "+ listUp);
  607. if(StringUtils.isNotBlank(infoMap.get("orderNo").toString())){
  608. orderNoP =infoMap.get("orderNo").toString();
  609. }
  610. if(infoMap.containsKey("createdDate") && infoMap.get("createdDate") !=null ){
  611. //格式化日期
  612. SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  613. createdDateP =sdf.format(infoMap.get("createdDate"));
  614. }
  615. if(infoMap.containsKey("stationName") && infoMap.get("stationName") !=null ){
  616. stationNameP =infoMap.get("stationName").toString();
  617. }
  618. if(infoMap.containsKey("oilName") && infoMap.get("oilName") !=null ){
  619. oilNameP =infoMap.get("oilName").toString();
  620. }
  621. //加油升数
  622. if(infoMap.containsKey("orderLiters") && infoMap.get("orderLiters") !=null ){
  623. orderLitersP =infoMap.get("orderLiters")+"";
  624. }
  625. //油价
  626. if(infoMap.containsKey("oilPirce") && infoMap.get("oilPirce") !=null ){
  627. oilPirceP =infoMap.get("oilPirce")+"";
  628. }
  629. if(infoMap.containsKey("receivableAmt") && infoMap.get("receivableAmt") !=null ){
  630. receivableAmtP =infoMap.get("receivableAmt")+"";
  631. }
  632. if(infoMap.containsKey("discountAmt") && infoMap.get("discountAmt") !=null ){
  633. discountAmtP =infoMap.get("discountAmt")+"";
  634. }
  635. if(infoMap.containsKey("amt") && infoMap.get("amt") !=null ){
  636. amtP =infoMap.get("amt")+"";
  637. }
  638. if(infoMap.containsKey("mobilePhone") && infoMap.get("mobilePhone") !=null ){
  639. String phone =infoMap.get("mobilePhone")+"";
  640. //手机号中间四位****代替
  641. mobilePhoneP = phone.substring(0, 3) + "****" + phone.substring(7, phone.length());
  642. }
  643. if(infoMap.containsKey("payWay") && infoMap.get("payWay") !=null ){
  644. if(infoMap.get("payWay").equals("02") || infoMap.get("payWay").equals("03")){
  645. payWayP ="微信";
  646. }
  647. }
  648. content1 = "<CB>支付小票--顾客联</CB><BR>";
  649. content1 += "订单号:"+orderNoP+" <BR>";
  650. content1 += "时间:"+createdDateP+" <BR>";
  651. content1 += "油站:"+stationNameP+" <BR>";
  652. content1 += "油品: "+oilNameP+" <BR>";
  653. content1 += "油量: "+orderLitersP+" 升<BR>";
  654. content1 += "单价: "+oilPirceP+" L/元<BR>";
  655. content1 += "<BOLD><B>原价: "+receivableAmtP+" 元</B></BOLD><BR>";
  656. content1 += "优惠: "+discountAmtP+" 元<BR>";
  657. content1 += "支付: "+amtP+" 元<BR>";
  658. content1 += "支付方式: "+payWayP+" <BR>";
  659. content1 += "<BR>";
  660. //content1 += "--------------------------------<BR>";
  661. content1 += "<BR>";
  662. content2 = "<CB>支付小票--商户联</CB><BR>";
  663. content2 += "订单号:"+orderNoP+" <BR>";
  664. content2 += "时间:"+createdDateP+"<BR>";
  665. content2 += "油站:"+stationNameP+" <BR>";
  666. content2 += "油品: "+oilNameP+" <BR>";
  667. content2 += "油量: "+orderLitersP+" 升<BR>";
  668. content2 += "单价: "+oilPirceP+" L/元<BR>";
  669. content2 += "<BOLD><B>原价: "+receivableAmtP+" 元</B></BOLD><BR>";
  670. content2 += "优惠: "+discountAmtP+" 元<BR>";
  671. content2 += "支付: "+amtP+" 元<BR>";
  672. content2 += "手机号: "+mobilePhoneP+" <BR>";
  673. content2 += "支付方式: "+payWayP+" <BR>";
  674. content2 += "<BR>";
  675. //获取打印机编号
  676. //sn = "921611605"; //测试打印机 sn:921611605 key:72338zma
  677. Map params =new HashMap();
  678. params.put("stationId", infoMap.get("stationId").toString());
  679. params.put("oilGunNo", infoMap.get("oilGun").toString());
  680. Map m = stationOilGunService.getPrinterSnByStationIdAndOilGunNo(params);
  681. if(m.containsKey("printerSn") && m.get("printerSn").toString()!= null && m.get("printerSn").toString()!=""){
  682. sn = m.get("printerSn").toString();
  683. // //查询打印机的状态
  684. // JSONObject jsonPrintStatus = JSONObject.parseObject(FeiEPrinterUtil.queryPrinterStatus(sn));
  685. // if(jsonPrintStatus.getString("data").equals("\\u5728\u7ebf\\uff0c\\u5de5\\u4f5c\\u72b6\u6001\\u6b63\\u5e38\\u3002")){
  686. // logger.info("打印机在线,工作状态正常:" + jsonPrintStatus.toString());
  687. //开始打印
  688. String printInfo=""; //打印信息
  689. if(m.containsKey("printSetting") && m.get("printSetting").toString()!= null && m.get("printSetting").toString()!=""){
  690. switch (m.get("printSetting").toString()){
  691. case "1": //1 客户联
  692. printInfo = FeiEPrinterUtil.printReceipt(sn, content1);
  693. break;
  694. case "2": //2 商户联
  695. printInfo = FeiEPrinterUtil.printReceipt(sn, content2);
  696. break;
  697. case "3": //3商户联和客户联
  698. printInfo = FeiEPrinterUtil.printReceipt(sn, content1 + content2);
  699. break;
  700. }
  701. }
  702. JSONObject jsonObject = JSONObject.parseObject(printInfo);
  703. if(jsonObject != null && jsonObject.getString("msg").equals("ok")){
  704. logger.info("打印成功:" + jsonObject.toString());
  705. //如果打印成功 添加小票数量
  706. PayOrder p = new PayOrder();
  707. p.setPrintCount(1);
  708. p.setOrderNo(ordNo);
  709. payOrderService.getUpdatePayOrder(p);
  710. }
  711. // }else if(jsonPrintStatus.getString("data").equals("\\u79bb\\u7ebf\\u3002")){
  712. // logger.info("打印机离线:" + jsonPrintStatus.toString());
  713. // }else if(jsonPrintStatus.getString("data").equals("\\u5728\\u7ebf\\uff0c\\u5de5\\u4f5c\\u72b6\\u6001\\u4e0d\\u6b63\\u5e38\\u3002")){
  714. // logger.info("打印机在线,纸异常: "+jsonPrintStatus.toString());
  715. // }
  716. }else {
  717. logger.info("请正确配置打印机");
  718. }
  719. }else{
  720. logger.info("该用户无手机号!");
  721. }
  722. }
  723. }
  724. }
  725. }else {
  726. logger.info("验签失败");
  727. req.put("code","fail");
  728. req.put("msg","失败");
  729. }
  730. }
  731. }