PayController.java 53 KB

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