PayController.java 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111
  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.*;
  8. import com.platform.yijia.service.*;
  9. import com.platform.yijia.utils.*;
  10. import com.platform.yijia.utils.redis.RedisCacheUtil;
  11. import com.platform.yijia.utils.weixinapp.WeiXinUserUtil;
  12. import com.platform.yijia.utils.weixinapp.WxPushUtil;
  13. import me.chanjar.weixin.mp.bean.template.WxMpTemplateData;
  14. import org.apache.commons.lang3.StringUtils;
  15. import org.slf4j.Logger;
  16. import org.slf4j.LoggerFactory;
  17. import org.springframework.stereotype.Controller;
  18. import org.springframework.transaction.annotation.Transactional;
  19. import org.springframework.web.bind.annotation.*;
  20. import javax.annotation.Resource;
  21. import java.math.BigDecimal;
  22. import java.math.RoundingMode;
  23. import java.text.ParseException;
  24. import java.text.SimpleDateFormat;
  25. import java.util.*;
  26. @Controller
  27. @RequestMapping("/demo")
  28. public class PayController {
  29. private static Logger logger =(Logger) LoggerFactory.getLogger(PayController.class);
  30. @Resource
  31. private PayOrderService payOrderService;
  32. @Resource
  33. private AppUserInfoService appUserInfoService;
  34. @Resource
  35. private StationOilGunService stationOilGunService;
  36. @Resource
  37. private CustomerGradeServices customerGradeServices;
  38. @Resource
  39. private StationService stationService;
  40. @Resource
  41. private CustomerPointsService customerPointsService;
  42. @Resource
  43. private IntegralRuleService integralRuleService;
  44. @Resource
  45. private CustomerPointsRecordService customerPointsRecordService;
  46. @Resource
  47. private RedisCacheUtil redisCacheUtil;
  48. @Resource
  49. private WxPushUtil wxPushUtil;
  50. /***
  51. * 微信子商户支付接口
  52. * @param weChatPaySetRequest
  53. * @return
  54. */
  55. @RequestMapping(value = "/weChatPaySet", consumes = "application/json", method = RequestMethod.POST)
  56. @ResponseBody
  57. public String weChatPaySet(@RequestBody WeChatPaySetRequest weChatPaySetRequest){
  58. Gson gson = new Gson();
  59. ResultData resultData = null; //返回结果
  60. try {
  61. String type = weChatPaySetRequest.getType(); //获取配置类型
  62. JSONObject reqData = new JSONObject(); //微信子商户支付参数配置
  63. reqData.put("mno", weChatPaySetRequest.getMno()); //商编
  64. reqData.put("subMchIdsubMchId", weChatPaySetRequest.getSubMchIdsubMchId()); //获取微信子商号
  65. if(type != null && type !=""){
  66. reqData.put("type", type);
  67. //根据类型设置必传参数
  68. switch (type){
  69. case "01": //支付Appid
  70. reqData.put("accountType", weChatPaySetRequest.getAccountType()); // 支付Appid类型 配置类型为01时必传
  71. reqData.put("subAppid", weChatPaySetRequest.getSubAppid()); // 支付Appid 配置类型为01,02时必传
  72. break;
  73. case "02": //关注Appid
  74. reqData.put("subAppid", weChatPaySetRequest.getSubAppid()); // 支付Appid 配置类型为01,02时必传
  75. reqData.put("subscribeAppid", weChatPaySetRequest.getSubscribeAppid()); // 推荐关注公众号Appid 配置类型为02时与推荐关注 小程序Appid二选一
  76. reqData.put("receiptAppid", weChatPaySetRequest.getReceiptAppid()); // 推荐关注小程序Appid 配置类型为02时与推荐关注 公众号Appid二选一
  77. break;
  78. case "03": //jsapi授权目录
  79. reqData.put("jsapiPath", weChatPaySetRequest.getJsapiPath()); // jsapi授权目录 配置类型为03时必传
  80. break;
  81. }
  82. }
  83. String sxfPay = SXFPaySign.getSXFPay(reqData); //封装传参信息,增加公共信息,增加业务信息
  84. logger.debug("参数信息:"+ sxfPay);
  85. System.out.println("req:" + sxfPay);
  86. //此处不要改变reqData里面值的顺序用LinkedHashMap
  87. HashMap reqMap = JSON.parseObject(sxfPay, LinkedHashMap.class, Feature.OrderedField);
  88. //组装加密串
  89. String signContent = RSASignature.getOrderContent(reqMap);
  90. System.out.println("拼接后的参数:" + signContent);
  91. logger.debug("拼接后的参数:"+signContent);
  92. //sign
  93. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  94. reqMap.put("sign", sign);
  95. String reqStr = JSON.toJSONString(reqMap);
  96. System.out.println("请求参数:" + reqMap);
  97. System.out.println("请求参数:" + reqStr);
  98. //String url = "https://openapi-test.tianquetech.com/merchant/weChatPaySet/addConf"; //测试环境
  99. String url = "https://openapi.tianquetech.com/merchant/weChatPaySet/addConf"; //生产环境
  100. //访问第三方接口
  101. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  102. System.out.println("返回信息:" + resultJson);
  103. // logger.debug("返回信息:"+resultJson);
  104. //不要对reqData排序 所以用LinkedHashMap
  105. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  106. if ("0000".equals(result.get("code"))) {
  107. //验签
  108. String signResult = result.get("sign").toString();
  109. result.remove("sign");
  110. String resultStr = RSASignature.getOrderContent(result);
  111. System.out.println(resultStr);
  112. //sign
  113. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  114. System.out.println("resultSign:" + resultSign);
  115. //组装加密串
  116. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  117. System.out.println("===================验签成功==============");
  118. }
  119. }
  120. resultData=ResultData.success(result);
  121. } catch (Exception e) {
  122. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"支付失败");
  123. e.printStackTrace();
  124. }
  125. return gson.toJson(resultData);
  126. }
  127. /**
  128. * 支付接口,前台上传支付信息,支付数据落地生产订单,调用随行付支付接口
  129. * @param
  130. * @return
  131. */
  132. @RequestMapping(value = "/getJhPayInfo", consumes = "application/json", method = RequestMethod.POST)
  133. @ResponseBody
  134. public String getJhPayInfo(@RequestBody PayInfoRequest payInfoRequest){
  135. Gson gson =new Gson();
  136. ResultData resultData =null;
  137. //String token=payInfoRequest.getToken();//token
  138. String openId = payInfoRequest.getOpenId(); //用户openId
  139. String userType=payInfoRequest.getUserType();//用户登录类型 1 公众号。2 小程序
  140. //String mno=payInfoRequest.getMno();//获取商户号
  141. Integer orderId =payInfoRequest.getOrderId();
  142. //根据token 和登录类型 身份验证
  143. AppUserInfo appUserInfo =new AppUserInfo();
  144. //订单类型 是小程序还是公众号
  145. appUserInfo.setUserType(userType);
  146. if(userType.equals("1")){
  147. //1 是公众号
  148. appUserInfo.setBlogOpenid(openId);
  149. }else if(userType.equals("2")){
  150. //2是小程序
  151. appUserInfo.setMinaOpenid(openId);
  152. }
  153. List<AppUserInfo> appUserInfoList =appUserInfoService.Authentication(appUserInfo);
  154. if(appUserInfoList!=null&&appUserInfoList.size()==1){
  155. //调用聚合支付
  156. try{
  157. //根据订单号查询订单信息
  158. PayOrder payOrder=payOrderService.searchPayOrder(orderId);
  159. if(payOrder!=null){
  160. //将业务参数存放在 JSON 对象中
  161. JSONObject reqData = new JSONObject();
  162. reqData.put("ordNo", payOrder.getOrderNo()); //商户订单号
  163. //reqData.put("subMechId", ""); //子商户号
  164. reqData.put("amt", payOrder.getAmt()); //订单总金额
  165. //reqData.put("amt", "0.01");
  166. //reqData.put("discountAmt", ""); //参与优惠金额
  167. //reqData.put("unDiscountAmt", ""); //不参与优惠金额
  168. reqData.put("payType", "WECHAT"); //支付渠道
  169. Map<String, String> stationAppIdAndAppSecret = stationService.getStationAppIdAndAppSecret(Integer.valueOf(payInfoRequest.getStationId()));
  170. if(stationAppIdAndAppSecret !=null && stationAppIdAndAppSecret.containsKey("appId") && stationAppIdAndAppSecret.containsKey("mno")){
  171. if(userType.equals("1")){
  172. reqData.put("subAppid", stationAppIdAndAppSecret.get("gzhAppId")); //微信公众号
  173. logger.info("支付子商户:"+ stationAppIdAndAppSecret.get("gzhAppId"));
  174. }else if(userType.equals("2")){
  175. reqData.put("subAppid", stationAppIdAndAppSecret.get("appId")); //微信小程序
  176. logger.info("支付子商户:"+ stationAppIdAndAppSecret.get("appId"));
  177. }
  178. reqData.put("mno", stationAppIdAndAppSecret.get("mno")); //商户编号
  179. logger.info("商户编号:"+ stationAppIdAndAppSecret.get("mno"));
  180. }
  181. if(userType.equals("1")){
  182. //1 是公众号
  183. reqData.put("payWay", "02"); //支付方式 02 公众号/服 务窗/js支付 03 小程序
  184. reqData.put("userId", appUserInfoList.get(0).getBlogOpenid()); //用户号 微信:openid; 支付宝:userid;银联:userid;微信&支付宝必传,银联js为非必传
  185. }else if(userType.equals("2")){
  186. //2是小程序
  187. reqData.put("payWay", "03"); //支付方式 02 公众号/服 务窗/js支付 03 小程序
  188. reqData.put("userId", appUserInfoList.get(0).getMinaOpenid()); //用户号 微信:openid; 支付宝:userid;银联:userid;微信&支付宝必传,银联js为非必传
  189. }
  190. //reqData.put("timeExpire", "10"); //订单失效时间, 以分钟为单位
  191. //reqData.put("limitPay", "00"); //限制卡类型: 00-全部 01-限定不能使 用信用卡支付 默认值 00
  192. if(StringUtils.isNotBlank(payInfoRequest.getSubject())){
  193. reqData.put("subject", payInfoRequest.getSubject()); //订单标题
  194. }else {
  195. reqData.put("subject", "聚合支付测试"); //订单标题
  196. }
  197. //reqData.put("hbFqNum", "6"); //花呗分期数,仅可上送 6 或 12
  198. reqData.put("tradeSource", "01"); //交易来源 01服务商,02收银台,03硬件
  199. reqData.put("trmIp", "172.16.2.1");//商家ip地址
  200. // reqData.put("customerIp", ""); //持卡人ip地址,银联js支付时必传
  201. //reqData.put("outFrontUrl", ""); //js 支付,前台 成功通知地址
  202. reqData.put("outFrontFailUrl", ""); //js 支付,前台 事变通知地址
  203. //reqData.put("notifyUrl", "https://www.huijy.net/api/getCallback"); //回调地址
  204. reqData.put("notifyUrl", "https://www.huijy.net/demo/getCallback"); //回调地址
  205. //reqData.put("needReceipt", "00"); //电子发票功能 微信开具电子 发票使用
  206. //reqData.put("ledgerAccountFlag", "00"); //是否做分账 分账交易使 用;00:做; 01:不做;不传默认为不做分账
  207. //reqData.put("ledgerAccountEffectTime", "00"); //分账有效时间 单位为天;是 否做分账选择 00 时该字段必传
  208. // reqData.put("ruleId", "00"); //同 步 分 账 规 则 id
  209. // reqData.put("fusruleId", "00"); //同步分账规则
  210. //reqData.put("ylTrmNo", ""); //银联终端号
  211. //reqData.put("terminalId", ""); //TQ机具编号
  212. //reqData.put("deviceNo ", "1111"); //设备号
  213. // reqData.put("identityFlag", ""); //是否是实名支付
  214. // reqData.put("buyerIdType", "IDCARD"); //证件类型
  215. // reqData.put("buyerIdNo", "410523198701054018"); //证件号
  216. // reqData.put("buyerName", "张三"); //买家姓名
  217. // reqData.put("mobileNum", ""); //手机号
  218. // reqData.put("extend", ""); //备用
  219. String req= SXFPaySign.getSXFPay(reqData);
  220. logger.debug("参数信息:"+req);
  221. System.out.println("req:" + req);
  222. //此处不要改变reqData里面值的顺序用LinkedHashMap
  223. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  224. //组装加密串
  225. String signContent = RSASignature.getOrderContent(reqMap);
  226. System.out.println("拼接后的参数:" + signContent);
  227. logger.debug("拼接后的参数:"+signContent);
  228. //sign
  229. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  230. System.out.println("============签名:" + sign);
  231. reqMap.put("sign", sign);
  232. String reqStr = JSON.toJSONString(reqMap);
  233. System.out.println("请求参数:" + reqMap);
  234. System.out.println("请求参数:" + reqStr);
  235. //调用第三方接口地址
  236. //String url = "https://openapi-test.tianquetech.com/order/jsapiScan";//测试地址
  237. String url = "https://openapi.suixingpay.com/order/jsapiScan";//生产地址
  238. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  239. System.out.println("返回信息:" + resultJson);
  240. // logger.debug("返回信息:"+resultJson);
  241. //不要对reqData排序 所以用LinkedHashMap
  242. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  243. if ("0000".equals(result.get("code"))) {
  244. //验签
  245. String signResult = result.get("sign").toString();
  246. result.remove("sign");
  247. String resultStr = RSASignature.getOrderContent(result);
  248. System.out.println(resultStr);
  249. //sign
  250. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  251. System.out.println("resultSign:" + resultSign);
  252. //组装加密串
  253. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  254. System.out.println("===================验签成功==============");
  255. }
  256. }
  257. resultData=ResultData.success(result);
  258. }else {
  259. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"未查询到订单");
  260. }
  261. }catch (Exception e){
  262. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"订单支付失败");
  263. e.printStackTrace();
  264. }
  265. }else{
  266. //返回失败支付失败信息
  267. resultData=ResultData.error(CodeMsg.USER_NOT_EXSIST);
  268. }
  269. return gson.toJson(resultData);
  270. }
  271. /**
  272. * 验证商户信息查询
  273. */
  274. @RequestMapping(value = "/getJhPayMnoInfo", method = RequestMethod.GET)
  275. @ResponseBody
  276. public String getJhPayMnoInfo(@RequestParam String mno){
  277. try {
  278. JSONObject reqData = new JSONObject();
  279. reqData.put("mno", mno); //商户编号
  280. String req = SXFPaySign.getSXFPay(reqData);
  281. logger.debug("参数信息:" + req);
  282. System.out.println("req:" + req);
  283. //此处不要改变reqData里面值的顺序用LinkedHashMap
  284. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  285. //组装加密串
  286. String signContent = RSASignature.getOrderContent(reqMap);
  287. System.out.println("拼接后的参数:" + signContent);
  288. logger.debug("拼接后的参数:" + signContent);
  289. //sign
  290. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  291. System.out.println("============签名:" + sign);
  292. reqMap.put("sign", sign);
  293. String reqStr = JSON.toJSONString(reqMap);
  294. System.out.println("请求参数:" + reqMap);
  295. System.out.println("请求参数:" + reqStr);
  296. //调用第三方接口地址
  297. //String url = "https://openapi-test.tianquetech.com/merchant/merchantInfoQuery";//测试地址
  298. String url = "https://openapi.tianquetech.com/merchant/merchantInfoQuery";//生产地址
  299. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  300. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  301. if ("0000".equals(result.get("code"))) {
  302. // //验签
  303. // String signResult = result.get("sign").toString();
  304. // result.remove("sign");
  305. // String resultStr = RSASignature.getOrderContent(result);
  306. // System.out.println(resultStr);
  307. // //sign
  308. // String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  309. // System.out.println("resultSign:" + resultSign);
  310. // //组装加密串
  311. // if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  312. // System.out.println("===================验签成功==============");
  313. // }
  314. }
  315. }catch (Exception e){
  316. e.printStackTrace();
  317. }
  318. return "";
  319. }
  320. /**
  321. * 关单接口
  322. */
  323. @RequestMapping(value = "/getPayOrderClose", consumes = "application/json", method = RequestMethod.POST)
  324. @ResponseBody
  325. public String getPayOrderClose(@RequestBody PayCloseRequestParamter payCloseRequestParamter) {
  326. String results="";
  327. Gson gson =new Gson();
  328. String mno=payCloseRequestParamter.getMno();
  329. String origOrderNo=payCloseRequestParamter.getOrigOrderNo();
  330. String origUuid=payCloseRequestParamter.getOrigUuid();
  331. String token=payCloseRequestParamter.getToken();
  332. String userType=payCloseRequestParamter.getUserType();
  333. boolean flag =appUserInfoService.selectAppUserInfo(token,userType);
  334. ResultData resultData =null;
  335. if(flag){
  336. try {
  337. JSONObject reqData = new JSONObject();
  338. reqData.put("mno",mno); //商户编号
  339. reqData.put("origOrderNo",origOrderNo);//系统商户订单号
  340. reqData.put("origUuid", origUuid);//随行付订单号
  341. String req= SXFPaySign.getSXFPay(reqData);
  342. //此处不要改变reqData里面值的顺序用LinkedHashMap
  343. HashMap reqMap = JSON.parseObject(req, LinkedHashMap.class, Feature.OrderedField);
  344. //组装加密串
  345. String signContent = RSASignature.getOrderContent(reqMap);
  346. System.out.println("拼接后的参数:" + signContent);
  347. //sign
  348. String sign = RSASignature.encryptBASE64(RSASignature.sign(signContent, SXFPaySign.privateKey));
  349. System.out.println("============签名:" + sign);
  350. reqMap.put("sign", sign);
  351. String reqStr = JSON.toJSONString(reqMap);
  352. System.out.println("请求参数:" + reqMap);
  353. System.out.println("请求参数:" + reqStr);
  354. //调用第三方接口地址
  355. // String url = "https://openapi-test.tianquetech.com/query/close";//测试地址
  356. String url = "https://openapi.tianquetech.com/query/close";//生产地址
  357. String resultJson = HttpUtils.connectPostUrl(url, reqStr);
  358. System.out.println("返回信息:" + resultJson);
  359. //不要对reqData排序 所以用LinkedHashMap
  360. HashMap<String, Object> result = JSON.parseObject(resultJson, LinkedHashMap.class, Feature.OrderedField);
  361. if ("0000".equals(result.get("code"))) {
  362. //验签
  363. String signResult = result.get("sign").toString();
  364. result.remove("sign");
  365. String resultStr = RSASignature.getOrderContent(result);
  366. System.out.println(resultStr);
  367. //sign
  368. String resultSign = RSASignature.encryptBASE64(RSASignature.sign(signContent,SXFPaySign.privateKey));
  369. System.out.println("resultSign:" + resultSign);
  370. //组装加密串
  371. if (RSASignature.doCheck(resultStr, signResult, SXFPaySign.sxfPublic)) {
  372. System.out.println("===================验签成功==============");
  373. }
  374. }
  375. resultData=ResultData.success(result);
  376. }catch (Exception e){
  377. resultData=ResultData.error(CodeMsg.YEWU_FAIL,"关闭订单失败");
  378. e.printStackTrace();
  379. }
  380. }else{
  381. resultData=ResultData.error(CodeMsg.USER_NOT_EXSIST);
  382. }
  383. return gson.toJson(resultData);
  384. }
  385. /**
  386. * 异步回调通知
  387. */
  388. @RequestMapping(value = "/getCallback", consumes = "application/json", method = RequestMethod.POST)
  389. @ResponseBody
  390. @Transactional
  391. public void getCallback(@RequestBody JSONObject request){
  392. logger.info("-------------------------------回调开始----------------------------------------------");
  393. logger.info("回调返回过来的参数"+request);
  394. logger.info("ordNo信息:" + request.get("ordNo").toString());
  395. logger.info("sign信息:" + request.get("sign").toString());
  396. Gson gson =new Gson();
  397. String sxfUuid=request.get("sxfUuid").toString(); //随行付落单号
  398. String payWay=request.get("payWay").toString(); //随行付交易方式
  399. String payTime=request.get("payTime").toString(); //随行付交易时间
  400. String uuid=request.get("uuid").toString(); //随行付交易流水号
  401. String mno=request.get("mno").toString();//发起交易的商户编号
  402. String ordNo=request.get("ordNo").toString();//商户生成的订单号
  403. String amt=request.get("amt").toString();//金额
  404. String buyerId=request.get("buyerId").toString();//用户登录
  405. String transactionId=request.get("transactionId").toString();//用户登录
  406. String drType=request.get("drType").toString();//借贷记标识 1-借,2-贷,3-其他
  407. String payType=request.get("payType").toString();//对订单的描述,取值范围:WECHAT:微信,ALIPAY:支付宝,UNIONPAY:
  408. String payBank=request.get("payBank").toString();//付款银行银行编码,例如 ICBC
  409. String pointAmount=request.get("pointAmount").toString();//代金券金额
  410. String totalOffstAmt=request.get("totalOffstAmt").toString();//消 费 者 付 款金额
  411. String settleAmt=request.get("settleAmt").toString();//商家入账金额
  412. String timeStamp=request.get("timeStamp").toString();//响应时间
  413. String sign=request.get("sign").toString();//签名
  414. String bizCode=request.get("bizCode").toString();//业务返回码
  415. String bizMsg=request.get("bizMsg").toString();//业 务 返 回 信息
  416. String openid=request.get("openid").toString();//微 信 或 支 付宝身份id()opendid userid
  417. String channelId=request.get("channelId").toString();//渠道商户号
  418. String subMechId=request.get("subMechId").toString();//子商户号
  419. String finishTime=request.get("finishTime").toString();//交易完成时间
  420. String clearDt=request.get("clearDt").toString();
  421. String settlementBatchNo=request.get("settlementBatchNo").toString();
  422. //String origOrdNo=request.get("origOrdNo").toString();//反交易退款异步通知
  423. //String origUuid=request.get("origUuid").toString();//token
  424. //String scene=request.get("scene").toString();//用户登录
  425. //String buyerAccount=request.get("buyerAccount").toString();//
  426. //String realRefundAmount=request.get("realRefundAmount").toString();//商家出账金额
  427. //String recFeeAmt=request.get("recFeeAmt").toString();//交易手续费
  428. //String recFeeRate=request.get("recFeeRate").toString();//交易手续费率
  429. //String refBuyerAmt=request.get("refBuyerAmt").toString();//消 费 者 到 账金额
  430. //String extend = extend=request.get("extend").toString();//备用
  431. //将业务参数存放在 JSON 对象中
  432. JSONObject reqData = new JSONObject();
  433. //备用
  434. if(request.containsKey("extend") && request.get("extend") !=null){
  435. String extend = request.get("extend").toString();
  436. reqData.put("extend", extend);
  437. }
  438. //优惠券参数
  439. if(request.containsKey("promotionDetail") && request.get("promotionDetail") !=null){
  440. String promotionDetail = request.get("promotionDetail").toString();
  441. reqData.put("promotionDetail", promotionDetail);
  442. }
  443. //商家出账金额
  444. if(request.containsKey("realRefundAmount") && request.get("realRefundAmount") !=null){
  445. String realRefundAmount = request.get("realRefundAmount").toString();
  446. reqData.put("realRefundAmount", realRefundAmount);
  447. }
  448. //szltFlag
  449. if(request.containsKey("szltFlag") && request.get("szltFlag") !=null){
  450. String szltFlag = request.get("szltFlag").toString();
  451. reqData.put("szltFlag", szltFlag);
  452. }
  453. //recFeeAmt
  454. if(request.containsKey("recFeeAmt") && request.get("recFeeAmt") !=null){
  455. String recFeeAmt = request.get("recFeeAmt").toString();
  456. reqData.put("recFeeAmt", recFeeAmt);
  457. }
  458. //szltRecfeeAmt
  459. if(request.containsKey("szltRecfeeAmt") && request.get("szltRecfeeAmt") !=null){
  460. String szltRecfeeAmt = request.get("szltRecfeeAmt").toString();
  461. reqData.put("szltRecfeeAmt", szltRecfeeAmt);
  462. }
  463. reqData.put("sxfUuid",sxfUuid);
  464. reqData.put("payWay",payWay);
  465. reqData.put("payTime",payTime);
  466. reqData.put("uuid",uuid);
  467. reqData.put("mno",mno);
  468. reqData.put("ordNo",ordNo);
  469. reqData.put("amt",amt);
  470. reqData.put("buyerId",buyerId);
  471. reqData.put("transactionId",transactionId);
  472. reqData.put("drType",drType);
  473. reqData.put("payType",payType);
  474. reqData.put("payBank",payBank);
  475. reqData.put("pointAmount",pointAmount);
  476. reqData.put("totalOffstAmt",totalOffstAmt);
  477. reqData.put("settleAmt",settleAmt);
  478. reqData.put("timeStamp",timeStamp);
  479. reqData.put("bizCode",bizCode);
  480. reqData.put("bizMsg",bizMsg);
  481. reqData.put("openid",openid);
  482. reqData.put("channelId",channelId);
  483. reqData.put("subMechId",subMechId);
  484. reqData.put("finishTime",finishTime);
  485. reqData.put("clearDt",clearDt);
  486. reqData.put("settlementBatchNo",settlementBatchNo);
  487. //reqData.put("realRefundAmount",realRefundAmount);
  488. //reqData.put("recFeeAmt",recFeeAmt);
  489. //reqData.put("recFeeRate",recFeeRate);
  490. //reqData.put("buyerAccount",buyerAccount);
  491. //reqData.put("origOrdNo",origOrdNo);
  492. //reqData.put("origUuid",origUuid);
  493. //reqData.put("scene",scene);
  494. //reqData.put("refBuyerAmt",refBuyerAmt);
  495. //reqData.put("extend",extend);
  496. //根据回调信息,先进行验签,验签后修改状态
  497. logger.info("打印参数信息"+gson.toJson(reqData));
  498. //不要对reqData排序 所以用LinkedHashMap
  499. HashMap<String, Object> result = JSON.parseObject(gson.toJson(reqData), LinkedHashMap.class, Feature.OrderedField);
  500. //验签
  501. String resultStr = RSASignature.getOrderContent(result);
  502. JSONObject req = new JSONObject();
  503. System.out.println(resultStr);
  504. if (RSASignature.doCheck(resultStr, sign, SXFPaySign.sxfPublic)) {
  505. logger.info("验签成功");
  506. //验签成功,修改订单状态
  507. List<PayOrder> list = payOrderService.getPayOrderList(ordNo);
  508. logger.info("根据订单号,查询订单"+gson.toJson(list));
  509. if (list != null && list.size() == 1) {
  510. String status = list.get(0).getStatus();
  511. //状态为未支付 0 修改状态为1已支付
  512. if (status.equals("0")) {
  513. PayOrder payOrder = new PayOrder();
  514. payOrder.setOrderNo(ordNo);
  515. payOrder.setStatus("1");
  516. payOrder.setPayDate(new Date()); //支付时间
  517. payOrder.setReceivedAmt(Double.valueOf(settleAmt)); //settleAmt商家入账金额
  518. //修改订单状态
  519. int count = payOrderService.getUpdatePayOrder(payOrder);
  520. if(count == 1){
  521. req.put("code","success");
  522. req.put("msg","修改订单状态成功");
  523. logger.info(req.toString());
  524. //将用户消费的信息插入顾客表: 以手机号 油品名称 油站id为条件插入且存入 加油升数、实收金额、油站名称 根据订单号查询用户手机号
  525. Map<String, Object> infoMap = payOrderService.getOrderInfoAndUserInfoByOrderNo(payOrder); //获取该订单手机号、加油升数、实收金额、油站名称
  526. logger.info("根据订单查询用户手机号等信息infoMap"+ infoMap.toString());
  527. //手机号必须有
  528. if(infoMap != null && infoMap.containsKey("mobilePhone") && infoMap.get("mobilePhone") !=null ){
  529. //存放客户信息
  530. CustomerManage customerManage = new CustomerManage();
  531. //存放查询用户信息
  532. AppUserInfo appUserInfo = new AppUserInfo();
  533. appUserInfo.setMobilePhone(infoMap.get("mobilePhone").toString());
  534. //从客户信息表查询数据用于插入客户表 使用List原因:app_user_info存在小程序和公众号两种信息
  535. List<AppUserInfo> appUserInfoList = payOrderService.getUserInfoByOpenId(appUserInfo);
  536. Date blogRegTime = null; //公众号注册时间
  537. Date minaRegTime = null; //小程序注册时间
  538. if(appUserInfoList != null && appUserInfoList.size() >0){
  539. for(AppUserInfo u : appUserInfoList){
  540. //向客户表插入小程序和公众号的openId 用户表ID 用户手机号 注册时间
  541. if(u.getUnionId() !=null && u.getUnionId() !=""){
  542. customerManage.setUnionId(u.getUnionId());
  543. }
  544. switch (u.getUserType()){
  545. case "1":
  546. customerManage.setBlogOpenid(u.getBlogOpenid());
  547. customerManage.setBlogUserId(u.getUserId());
  548. customerManage.setPhoneNumber(u.getMobilePhone());
  549. customerManage.setCustomerName(u.getBlogNickName());
  550. blogRegTime =u.getRegisteDate();
  551. break;
  552. case "2":
  553. customerManage.setMinaOpenid(u.getMinaOpenid());
  554. customerManage.setMinaUserId(u.getUserId());
  555. customerManage.setPhoneNumber(u.getMobilePhone());
  556. customerManage.setCustomerName(u.getBlogNickName());
  557. minaRegTime = u.getRegisteDate();
  558. break;
  559. }
  560. }
  561. //判断公众号和小程序时间取最早的时间
  562. if(blogRegTime !=null && minaRegTime != null){
  563. if(blogRegTime.compareTo(minaRegTime) >0){
  564. customerManage.setRegtime(minaRegTime);
  565. }else if(blogRegTime.compareTo(minaRegTime) <0){
  566. customerManage.setRegtime(blogRegTime);
  567. }else if(blogRegTime.compareTo(minaRegTime) ==0){
  568. //相等时随便取一个
  569. customerManage.setRegtime(minaRegTime);
  570. }
  571. }else if(blogRegTime == null){
  572. customerManage.setRegtime(minaRegTime);
  573. }else if(minaRegTime == null){
  574. customerManage.setRegtime(blogRegTime);
  575. }
  576. }
  577. customerManage.setStationId(Integer.valueOf(infoMap.get("stationId").toString())); //油站ID
  578. customerManage.setOilName(infoMap.get("oilName").toString()); //油品名称
  579. customerManage.setStationName(infoMap.get("stationName").toString()); //存入油站名称
  580. //已存在用户信息 existCustomer
  581. CustomerManage existCustomer = payOrderService.isExistCustomer(customerManage);
  582. logger.info("查询出客户是否存在数据 null 表示没有" + existCustomer);
  583. //获取该油站的优惠方式
  584. String discountPlanType = stationService.getStationDiscountWay(infoMap.get("stationId").toString());
  585. logger.info("油站优惠方式:"+discountPlanType);
  586. //判断该用户是否已存在
  587. if(existCustomer != null){ //存在该用户时更新
  588. //此处if放null处理
  589. if(existCustomer.getAmt() !=null){
  590. //存入金额 累加原来金额
  591. customerManage.setAmt(existCustomer.getAmt().add(BigDecimal.valueOf((Double) infoMap.get("amt"))));
  592. }else {
  593. customerManage.setAmt(BigDecimal.valueOf((Double) infoMap.get("amt")));
  594. }
  595. if(infoMap.containsKey("orderType") && infoMap.get("orderType").equals("1")) {
  596. if (existCustomer.getLiters() != null) {
  597. //存入升数 累加原来升数
  598. customerManage.setLiters(existCustomer.getLiters().add(BigDecimal.valueOf((Double) infoMap.get("orderLiters"))));
  599. } else {
  600. customerManage.setLiters(BigDecimal.valueOf((Double) infoMap.get("orderLiters")));
  601. }
  602. }
  603. logger.info("存在客户 更新时手机号参数: " + customerManage.getPhoneNumber());
  604. if(discountPlanType !=null && discountPlanType.equals("1")){
  605. //直降时存入等级名称和等级ID
  606. List<Map> customerGradeInfo = customerGradeServices.getCustomerGradeList(infoMap); //直降
  607. logger.info("该站直降等级信息:"+ customerGradeInfo);
  608. for (Map m: customerGradeInfo){
  609. if(Double.valueOf(customerManage.getAmt().toString()) >= Double.valueOf(m.get("memberConditStart").toString()) && Double.valueOf(customerManage.getAmt().toString()) < Double.valueOf(m.get("memberConditEnd").toString())){
  610. customerManage.setGrade(m.get("grade").toString()); //存入等级名称
  611. customerManage.setMemberGrade(m.get("id").toString()); //存入等级ID
  612. break;
  613. }
  614. }
  615. logger.info("直降等级信息是否存入客户表:"+ "直降ID:"+ customerManage.getMemberGrade()+ "直降名称: "+customerManage.getGrade());
  616. }
  617. //存在 更新
  618. payOrderService.updateCustomer(customerManage);
  619. }else{
  620. //该客户不存在时插入
  621. if(discountPlanType !=null && discountPlanType.equals("1")){
  622. //直降时存入等级名称和等级ID
  623. List<Map> customerGradeInfo = customerGradeServices.getCustomerGradeList(infoMap); //直降
  624. logger.info("该站直降等级信息:"+ customerGradeInfo);
  625. if(customerGradeInfo !=null && customerGradeInfo.size() >0){
  626. customerManage.setGrade(customerGradeInfo.get(0).get("grade").toString()); //存入等级名称
  627. customerManage.setMemberGrade(customerGradeInfo.get(0).get("id").toString()); //存入等级ID
  628. }
  629. logger.info("直降等级信息是否存入客户表:"+ "直降ID:"+ customerManage.getMemberGrade()+ "直降名称: "+customerManage.getGrade());
  630. }
  631. customerManage.setAmt(BigDecimal.valueOf((Double) infoMap.get("amt"))); //存入金额
  632. if(infoMap.containsKey("orderType") && infoMap.get("orderType").equals("1")){
  633. customerManage.setLiters(BigDecimal.valueOf((Double) infoMap.get("orderLiters"))); //存入升数
  634. }
  635. //不存在 新增
  636. logger.info("不存在客户 新增时参数: " + customerManage.toString());
  637. payOrderService.insertCustomer(customerManage);
  638. }
  639. //==========================================================================================================================================================//
  640. //计算积分并推送
  641. CalculateIntegral calculateIntegral = new CalculateIntegral();
  642. calculateIntegral.setOpenId(infoMap.get("minaOpenid").toString());
  643. calculateIntegral.setStationId(Integer.valueOf(infoMap.get("stationId").toString()));
  644. calculateIntegral.setAmt(new BigDecimal(infoMap.get("amt").toString()));
  645. if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("1")){
  646. calculateIntegral.setOilType(infoMap.get("orderType").toString());
  647. calculateIntegral.setOilName(infoMap.get("oilName").toString());
  648. calculateIntegral.setOilLiters(new BigDecimal(infoMap.get("orderLiters").toString()));
  649. }else if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("2")){
  650. calculateIntegral.setOilType(infoMap.get("orderType").toString());
  651. }
  652. calculateIntegral.setReceivableAmt(new BigDecimal(infoMap.get("receivableAmt").toString()));
  653. //计算积分并推送
  654. this.calculateIntegralAndPushIntegral(calculateIntegral, customerManage);
  655. ///========================================================================================================================================================//
  656. //打印机打印小票
  657. String content1;
  658. String content2;
  659. String orderNoP = "";
  660. String createdDateP ="";
  661. String stationNameP ="";
  662. String oilNameP ="";
  663. String orderLitersP ="";
  664. String oilPirceP ="";
  665. String receivableAmtP = "";
  666. String discountAmtP = "";
  667. String amtP = "";
  668. String mobilePhoneP = "";
  669. String payWayP = "";
  670. String sn; //打印机编号
  671. if(StringUtils.isNotBlank(infoMap.get("orderNo").toString())){
  672. orderNoP =infoMap.get("orderNo").toString();
  673. }
  674. if(infoMap.containsKey("createdDate") && infoMap.get("createdDate") !=null ){
  675. //格式化日期
  676. SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  677. createdDateP =sdf.format(infoMap.get("createdDate"));
  678. }
  679. if(infoMap.containsKey("stationName") && infoMap.get("stationName") !=null ){
  680. stationNameP =infoMap.get("stationName").toString();
  681. }
  682. if(infoMap.containsKey("oilName") && infoMap.get("oilName") !=null ){
  683. oilNameP =infoMap.get("oilName").toString();
  684. }
  685. if(infoMap.containsKey("orderType") && infoMap.get("orderType").equals("1")) {
  686. //加油升数
  687. if (infoMap.containsKey("orderLiters") && infoMap.get("orderLiters") != null) {
  688. orderLitersP = infoMap.get("orderLiters") + "";
  689. }
  690. //油价
  691. if (infoMap.containsKey("oilPirce") && infoMap.get("oilPirce") != null) {
  692. oilPirceP = infoMap.get("oilPirce") + "";
  693. }
  694. if(infoMap.containsKey("discountAmt") && infoMap.get("discountAmt") !=null ){
  695. discountAmtP =infoMap.get("discountAmt")+"";
  696. }
  697. }else if(infoMap.containsKey("orderType") && infoMap.get("orderType").equals("2")) {
  698. orderLitersP ="0.00";
  699. oilPirceP = "0.00";
  700. discountAmtP ="0.00";
  701. receivableAmtP=infoMap.get("amt")+"";
  702. }
  703. if(infoMap.containsKey("receivableAmt") && infoMap.get("receivableAmt") !=null ){
  704. receivableAmtP =infoMap.get("receivableAmt")+"";
  705. }
  706. if(infoMap.containsKey("amt") && infoMap.get("amt") !=null ){
  707. amtP =infoMap.get("amt")+"";
  708. }
  709. if(infoMap.containsKey("mobilePhone") && infoMap.get("mobilePhone") !=null ){
  710. String phone =infoMap.get("mobilePhone")+"";
  711. //手机号中间四位****代替
  712. mobilePhoneP = phone.substring(0, 3) + "****" + phone.substring(7, phone.length());
  713. }
  714. if(infoMap.containsKey("payWay") && infoMap.get("payWay") !=null ){
  715. if(infoMap.get("payWay").equals("02") || infoMap.get("payWay").equals("03")){
  716. payWayP ="微信";
  717. }
  718. }
  719. content1 = "<CB>支付小票--顾客联</CB><BR>";
  720. content1 += "订单号:"+orderNoP+" <BR>";
  721. content1 += "时间:"+createdDateP+" <BR>";
  722. content1 += "油站:"+stationNameP+" <BR>";
  723. if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("1")){
  724. content1 += "油品: "+oilNameP+" <BR>";
  725. content1 += "油量: "+orderLitersP+" 升<BR>";
  726. content1 += "单价: "+oilPirceP+" L/元<BR>";
  727. }
  728. content1 += "<BOLD><B>原价: "+receivableAmtP+" 元</B></BOLD><BR>";
  729. if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("1")){
  730. content1 += "优惠: "+discountAmtP+" 元<BR>";
  731. }
  732. content1 += "支付: "+amtP+" 元<BR>";
  733. content1 += "支付方式: "+payWayP+" <BR>";
  734. content1 += "<BR>";
  735. //content1 += "--------------------------------<BR>";
  736. content1 += "<BR>";
  737. content2 = "<CB>支付小票--商户联</CB><BR>";
  738. content2 += "订单号:"+orderNoP+" <BR>";
  739. content2 += "时间:"+createdDateP+"<BR>";
  740. content2 += "油站:"+stationNameP+" <BR>";
  741. if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("1")){
  742. content2 += "油品: "+oilNameP+" <BR>";
  743. content2 += "油量: "+orderLitersP+" 升<BR>";
  744. content2 += "单价: "+oilPirceP+" L/元<BR>";
  745. }
  746. content2 += "<BOLD><B>原价: "+receivableAmtP+" 元</B></BOLD><BR>";
  747. if(infoMap.containsKey("orderType") && infoMap.get("orderType").toString().equals("1")){
  748. content2 += "优惠: "+discountAmtP+" 元<BR>";
  749. }
  750. content2 += "支付: "+amtP+" 元<BR>";
  751. content2 += "手机号: "+mobilePhoneP+" <BR>";
  752. content2 += "支付方式: "+payWayP+" <BR>";
  753. content2 += "<BR>";
  754. //获取打印机编号
  755. //sn = "921611605"; //测试打印机 sn:921611605 key:72338zma
  756. Map params =new HashMap();
  757. params.put("stationId", infoMap.get("stationId").toString());
  758. params.put("oilGunNo", infoMap.get("oilGun").toString());
  759. Map m = stationOilGunService.getPrinterSnByStationIdAndOilGunNo(params);
  760. if(m !=null && m.containsKey("printerSn") && m.get("printerSn").toString()!= null && m.get("printerSn").toString()!=""){
  761. sn = m.get("printerSn").toString();
  762. // //查询打印机的状态
  763. // JSONObject jsonPrintStatus = JSONObject.parseObject(FeiEPrinterUtil.queryPrinterStatus(sn));
  764. // if(jsonPrintStatus.getString("data").equals("\\u5728\u7ebf\\uff0c\\u5de5\\u4f5c\\u72b6\u6001\\u6b63\\u5e38\\u3002")){
  765. // logger.info("打印机在线,工作状态正常:" + jsonPrintStatus.toString());
  766. //开始打印
  767. String printInfo=""; //打印信息
  768. if(m.containsKey("printSetting") && m.get("printSetting").toString()!= null && m.get("printSetting").toString()!=""){
  769. switch (m.get("printSetting").toString()){
  770. case "1": //1 客户联
  771. printInfo = FeiEPrinterUtil.printReceipt(sn, content1);
  772. break;
  773. case "2": //2 商户联
  774. printInfo = FeiEPrinterUtil.printReceipt(sn, content2);
  775. break;
  776. case "3": //3商户联和客户联
  777. printInfo = FeiEPrinterUtil.printReceipt(sn, content1 + content2);
  778. break;
  779. }
  780. }
  781. JSONObject jsonObject = JSONObject.parseObject(printInfo);
  782. if(jsonObject != null && jsonObject.getString("msg").equals("ok")){
  783. logger.info("打印成功:" + jsonObject.toString());
  784. //如果打印成功 添加小票数量
  785. PayOrder p = new PayOrder();
  786. p.setPrintCount(1);
  787. p.setOrderNo(ordNo);
  788. payOrderService.getUpdatePayOrder(p);
  789. }
  790. // }else if(jsonPrintStatus.getString("data").equals("\\u79bb\\u7ebf\\u3002")){
  791. // logger.info("打印机离线:" + jsonPrintStatus.toString());
  792. // }else if(jsonPrintStatus.getString("data").equals("\\u5728\\u7ebf\\uff0c\\u5de5\\u4f5c\\u72b6\\u6001\\u4e0d\\u6b63\\u5e38\\u3002")){
  793. // logger.info("打印机在线,纸异常: "+jsonPrintStatus.toString());
  794. // }
  795. }else {
  796. logger.info("请正确配置打印机");
  797. }
  798. }else{
  799. logger.info("该用户无手机号!");
  800. }
  801. }
  802. }
  803. }
  804. }else {
  805. logger.info("验签失败");
  806. req.put("code","fail");
  807. req.put("msg","失败");
  808. }
  809. }
  810. /**
  811. * 计算消费生成积分
  812. * 注释: 1.判断油站配置的优惠类型
  813. * 2.如果是等级直降则存在等级取对应等级的积分规则,否则按照其他优惠方式
  814. */
  815. public void calculateIntegralAndPushIntegral(CalculateIntegral calculateIntegral, CustomerManage customerManage){
  816. int integral =0;
  817. //获取该油站的优惠方式
  818. String discountPlanType = stationService.getStationDiscountWay(calculateIntegral.getStationId().toString());
  819. IntegralRule integralRule = new IntegralRule();
  820. integralRule.setStationId(calculateIntegral.getStationId());
  821. integralRule.setEmptyDate(new Date());
  822. integralRule.setOilName(calculateIntegral.getOilName());
  823. integralRule.setOilType(calculateIntegral.getOilType());
  824. //获取该油站的积分规则
  825. List<IntegralRule> integralRuleList = integralRuleService.getIntegralRule(integralRule);
  826. if(integralRuleList !=null && integralRuleList.size() >0){
  827. logger.info("该油站积分规则信息:" + integralRuleList.toString());
  828. List<IntegralRuleDetail> integralRuleDetailList = integralRuleList.get(0).getIntegralRuleDetailList();
  829. String currentTime = null; //当前时间
  830. String datePickerTime=null; //活动时间
  831. String[] datePickerTimeArray ={};
  832. String integralActivity = integralRuleList.get(0).getIntegralActivity();
  833. String integralProportion =null;
  834. if(integralActivity !=null && integralActivity.equals("1")){
  835. datePickerTime = integralRuleList.get(0).getDatePickerTime();
  836. integralProportion = integralRuleList.get(0).getIntegralProportion();
  837. if(datePickerTime.contains(",")){
  838. datePickerTimeArray = datePickerTime.split(",");
  839. }else {
  840. datePickerTimeArray= new String[1];
  841. datePickerTimeArray[0] = datePickerTime;
  842. }
  843. }
  844. if(integralRuleDetailList !=null && integralRuleDetailList.size() >0){
  845. Calendar calendar = Calendar.getInstance();
  846. calendar.setTime(new Date()); //获取当前时间
  847. for (IntegralRuleDetail integralRuleDetail : integralRuleDetailList){
  848. if(integralRuleDetail.getOilType().equals("1")){ //油品
  849. if (integralRuleDetail.getRuleType().equals("1")){ //按照实收金额
  850. if(calculateIntegral.getAmt().compareTo(integralRuleDetail.getRuleTerms()) == 1 || calculateIntegral.getAmt().compareTo(integralRuleDetail.getRuleTerms()) == 0){
  851. BigDecimal divide = null;
  852. BigDecimal multiply = null;
  853. //判断油站配置的优惠类型
  854. if(discountPlanType.equals("1") && integralRuleDetail.getGread() !=null && customerManage.getGrade().equals(integralRuleDetail.getGread())){ //等级直降
  855. divide = calculateIntegral.getAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  856. multiply = divide.multiply(integralRuleDetail.getIntegral());
  857. }else {
  858. divide = calculateIntegral.getAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  859. multiply = divide.multiply(integralRuleDetail.getIntegral());
  860. }
  861. if(integralActivity !=null && integralActivity.equals("1") && datePickerTimeArray !=null && integralProportion !=null){
  862. String datePicker = integralRuleList.get(0).getDatePicker();
  863. switch (datePicker){
  864. case "1": // 1.按周来
  865. int day_Week = calendar.get(Calendar.DAY_OF_WEEK);
  866. day_Week= day_Week-1; //减一原因:数据库存的下标从零开始
  867. currentTime = String.valueOf(day_Week);
  868. break;
  869. case "2": // 2.每月的多少号
  870. int day_month = calendar.get(Calendar.DAY_OF_MONTH);
  871. day_month = day_month-1; //减一原因:数据库存的下标从零开始
  872. currentTime = String.valueOf(day_month); //当前时间
  873. break;
  874. case "3": // 3.固定日期
  875. currentTime =new SimpleDateFormat("yyyy-MM-dd").format(new Date());
  876. break;
  877. }
  878. for (String s : datePickerTimeArray){
  879. if(s.equals(currentTime)){
  880. multiply = multiply.multiply(new BigDecimal(integralProportion));
  881. break;
  882. }
  883. }
  884. }
  885. integral =multiply.intValue();
  886. logger.info("本次客户所得积分:" + integral);
  887. break;
  888. }
  889. }else if (integralRuleDetail.getRuleType().equals("2")){ //按应收金额
  890. if(calculateIntegral.getReceivableAmt().compareTo(integralRuleDetail.getRuleTerms()) ==1 || calculateIntegral.getReceivableAmt().compareTo(integralRuleDetail.getRuleTerms()) ==0){
  891. BigDecimal divide = null;
  892. BigDecimal multiply = null;
  893. //判断油站配置的优惠类型
  894. if(discountPlanType.equals("1") && integralRuleDetail.getGread() !=null && customerManage.getGrade().equals(integralRuleDetail.getGread())){ //等级直降
  895. divide = calculateIntegral.getReceivableAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  896. multiply = divide.multiply(integralRuleDetail.getIntegral());
  897. }else {
  898. divide = calculateIntegral.getReceivableAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  899. multiply = divide.multiply(integralRuleDetail.getIntegral());
  900. }
  901. if(integralActivity !=null && integralActivity.equals("1") && datePickerTimeArray !=null && integralProportion !=null){
  902. String datePicker = integralRuleList.get(0).getDatePicker();
  903. switch (datePicker){
  904. case "1": // 1.按周来
  905. int day_Week = calendar.get(Calendar.DAY_OF_WEEK);
  906. day_Week= day_Week-1; //减一原因:数据库存的下标从零开始
  907. currentTime = String.valueOf(day_Week);
  908. break;
  909. case "2": // 2.每月的 多少号
  910. int day_month = calendar.get(Calendar.DAY_OF_MONTH);
  911. day_month = day_month-1; //减一原因:数据库存的下标从零开始
  912. currentTime = String.valueOf(day_month); //当前时间
  913. break;
  914. case "3": // 3.固定日期
  915. currentTime =new SimpleDateFormat("yyyy-MM-dd").format(new Date()); //当前时间
  916. break;
  917. }
  918. for (String s : datePickerTimeArray){
  919. if(s.equals(currentTime)){
  920. multiply = multiply.multiply(new BigDecimal(integralProportion));
  921. break;
  922. }
  923. }
  924. }
  925. integral = multiply.intValue();
  926. logger.info("本次客户所得积分:" + integral);
  927. break;
  928. }
  929. }else if (integralRuleDetail.getRuleType().equals("3")){ //按照加油升数
  930. if(calculateIntegral.getOilLiters().compareTo(integralRuleDetail.getRuleTerms()) ==1 || calculateIntegral.getOilLiters().compareTo(integralRuleDetail.getRuleTerms()) ==0){
  931. BigDecimal divide = null;
  932. BigDecimal multiply = null;
  933. //判断油站配置的优惠类型
  934. if(discountPlanType.equals("1") && integralRuleDetail.getGread() !=null && customerManage.getGrade().equals(integralRuleDetail.getGread())){ //等级直降
  935. divide = calculateIntegral.getOilLiters().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  936. multiply = divide.multiply(integralRuleDetail.getIntegral());
  937. }else {
  938. divide = calculateIntegral.getOilLiters().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  939. multiply = divide.multiply(integralRuleDetail.getIntegral());
  940. }
  941. if(integralActivity !=null && integralActivity.equals("1") && datePickerTimeArray !=null && integralProportion !=null){
  942. String datePicker = integralRuleList.get(0).getDatePicker();
  943. switch (datePicker){
  944. case "1": // 1.按周来
  945. int day_Week = calendar.get(Calendar.DAY_OF_WEEK);
  946. day_Week= day_Week-1; //减一原因:数据库存的下标从零开始
  947. currentTime = String.valueOf(day_Week);
  948. break;
  949. case "2": // 2.每月的 多少号
  950. int day_month = calendar.get(Calendar.DAY_OF_MONTH);
  951. day_month = day_month-1; //减一原因:数据库存的下标从零开始
  952. currentTime = String.valueOf(day_month); //当前时间
  953. break;
  954. case "3": // 3.固定日期
  955. currentTime =new SimpleDateFormat("yyyy-MM-dd").format(new Date()); //当前时间
  956. break;
  957. }
  958. for (String s : datePickerTimeArray){
  959. if(s.equals(currentTime)){
  960. multiply = multiply.multiply(new BigDecimal(integralProportion));
  961. break;
  962. }
  963. }
  964. }
  965. integral =multiply.intValue();
  966. logger.info("本次客户所得积分:" + integral);
  967. break;
  968. }
  969. }
  970. }else if (integralRuleDetail.getOilType().equals("2")){ //非油品
  971. if (calculateIntegral.getReceivableAmt().compareTo(integralRuleDetail.getRuleTerms()) ==1 || calculateIntegral.getReceivableAmt().compareTo(integralRuleDetail.getRuleTerms()) ==0){
  972. BigDecimal divide = null;
  973. BigDecimal multiply = null;
  974. //判断油站配置的优惠类型
  975. if(discountPlanType.equals("1") && integralRuleDetail.getGread() !=null && customerManage.getGrade().equals(integralRuleDetail.getGread())){ //等级直降
  976. divide = calculateIntegral.getReceivableAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  977. multiply = divide.multiply(integralRuleDetail.getIntegral());
  978. }else {
  979. divide = calculateIntegral.getReceivableAmt().divide(integralRuleDetail.getSaleAmt(), 0, BigDecimal.ROUND_HALF_DOWN);
  980. multiply = divide.multiply(integralRuleDetail.getIntegral());
  981. }
  982. if(integralActivity !=null && integralActivity.equals("1") && datePickerTimeArray !=null && integralProportion !=null){
  983. String datePicker = integralRuleList.get(0).getDatePicker(); //获取日期类型
  984. switch (datePicker){
  985. case "1": // 1.按周来
  986. int day_Week = calendar.get(Calendar.DAY_OF_WEEK);
  987. day_Week= day_Week-1; //减一原因:数据库存的下标从零开始
  988. currentTime = String.valueOf(day_Week);
  989. break;
  990. case "2": // 2.每月的 多少号
  991. int day_month = calendar.get(Calendar.DAY_OF_MONTH);
  992. day_month = day_month-1; //减一原因:数据库存的下标从零开始
  993. currentTime = String.valueOf(day_month); //当前时间
  994. break;
  995. case "3": // 3.固定日期
  996. currentTime =new SimpleDateFormat("yyyy-MM-dd").format(new Date()); //当前时间
  997. break;
  998. }
  999. for (String s : datePickerTimeArray){
  1000. if(s.equals(currentTime)){
  1001. multiply = multiply.multiply(new BigDecimal(integralProportion));
  1002. break;
  1003. }
  1004. }
  1005. }
  1006. integral = multiply.intValue();
  1007. logger.info("本次客户所得积分:" + integral);
  1008. break;
  1009. }
  1010. }
  1011. }
  1012. }
  1013. this.pushIntegral(calculateIntegral.getStationId(), integral, calculateIntegral.getOpenId());
  1014. }
  1015. }
  1016. /*
  1017. * 公众号推送积分
  1018. * @param stationId 油站ID
  1019. * @param integral 本次所得积分
  1020. * @param openId 小程序用户openID
  1021. */
  1022. public void pushIntegral(Integer stationId, int integral, String openId){
  1023. String gzhAppId ="";
  1024. String gzhAppSecret ="";
  1025. String stationName = ""; //油站名称
  1026. BigDecimal surplusIntegral=null;
  1027. String customerName =null;
  1028. if(StringUtils.isNotBlank(openId)){
  1029. Map<String, String> m = stationService.getStationAppIdAndAppSecret(stationId);
  1030. if(m !=null && m.containsKey("stationName") && m.containsKey("gzhAppId") && m.containsKey("gzhAppSecret")){
  1031. stationName = m.get("stationName");
  1032. gzhAppId = m.get("gzhAppId");
  1033. gzhAppSecret = m.get("gzhAppSecret");
  1034. }
  1035. CustomerPoints customerPoints = new CustomerPoints();
  1036. customerPoints.setStationId(stationId);
  1037. customerPoints.setMinaOpenId(openId);
  1038. CustomerPoints customerPointsInfo = customerPointsService.getCustomerPointsInfoByMinaOpenId(customerPoints);
  1039. if(customerPointsInfo !=null){
  1040. customerName =customerPointsInfo.getCustomerName();
  1041. surplusIntegral =new BigDecimal(customerPointsInfo.getPoints()).add(new BigDecimal(integral));
  1042. CustomerPointsRecord customerPointsRecord = new CustomerPointsRecord();
  1043. customerPointsRecord.setCreateTime(new Date());
  1044. customerPointsRecord.setCustomerName(customerName);
  1045. customerPointsRecord.setStationName(stationName);
  1046. customerPointsRecord.setStationId(stationId);
  1047. customerPointsRecord.setRecordType("+");
  1048. customerPointsRecord.setUnionId(customerPointsInfo.getUnionId());
  1049. customerPointsRecord.setIntegral(integral);
  1050. customerPointsRecordService.insertCustomerPointsRecordInfo(customerPointsRecord);
  1051. customerPoints.setUnionId(customerPointsInfo.getUnionId());
  1052. customerPoints.setPoints(surplusIntegral.intValue());
  1053. //更新客户积分
  1054. customerPointsService.updateCustomerPointsInfo(customerPoints);
  1055. String blogOpenId = customerPointsInfo.getBlogOpenId(); //公众号openId
  1056. if(blogOpenId !=null){
  1057. //推送模板
  1058. List<WxMpTemplateData> wxMpTemplate = new ArrayList<>();
  1059. wxMpTemplate.add(new WxMpTemplateData("first","尊敬的"+customerName+",您好:\n" + "您在"+stationName+"的积分最新交易信息如下"));
  1060. wxMpTemplate.add(new WxMpTemplateData("time", new SimpleDateFormat("yyyy年MM月dd日HH时mm分").format(new Date())));
  1061. wxMpTemplate.add(new WxMpTemplateData("type", "增加"));
  1062. wxMpTemplate.add(new WxMpTemplateData("Point", String.valueOf(integral)));
  1063. wxMpTemplate.add(new WxMpTemplateData("From", stationName));
  1064. wxMpTemplate.add(new WxMpTemplateData("remark",
  1065. "截止至" + new SimpleDateFormat(" yyyy年MM月dd日HH时mm分").format(new Date())+",您在"+stationName+"的可用积分为 "+surplusIntegral.toString()+" 分"));
  1066. String templateId = "G9tN--a3tGM5BN3otqZr73b4ErQCYWISSgyshbTqLYc"; //积分兑换成功通知模板
  1067. wxPushUtil.push(gzhAppId, gzhAppSecret, templateId, blogOpenId, wxMpTemplate); //oJR5R6r4EJhaORFcPap70r_mtFZo
  1068. }
  1069. }
  1070. }
  1071. }
  1072. }