public TrackContext getTrackData(String key, String input) throws HSMException { String track2Str = null; String track3Str = null; try { byte[] tracks = hsmService.descryptData( HSM.ALGFLAG_3DES_2ECB, CodecUtils.hex2byte(key), CodecUtils.hex2byte(input)); String trackStr = ISOUtils.bcd2str(tracks, 0, tracks.length * 2, true); int offset = 0; int lengthLen = 2; int track2Len = Integer.valueOf(trackStr.substring(offset, offset + lengthLen)); offset += lengthLen; track2Str = trackStr.substring(offset, offset + track2Len); offset += track2Len; lengthLen = 3; int track3Len = Integer.valueOf(trackStr.substring(offset, offset + lengthLen)); offset += lengthLen; track3Str = trackStr.substring(offset, offset + track3Len); } catch (Exception e) { e.printStackTrace(); throw new HSMException(HSMExcCode.DECODE_TRACK_ERROR, "[解密磁道数据失败!]"); } return new TrackContext(track2Str, track3Str); }
public UlinkplusResponseInfo process( CupsTrmnl cupsTrmnl, UlinkplusKeyManage ulinkplusKeyManage, UlinkplusRequestInfo request) throws TransferFailedException { logger.info("ulinkplus渠道信用卡手续费查询开始..."); // 1.组装报文 CreditcardFeeQueryTradeRequestEntity requestEntity = packUp(cupsTrmnl, ulinkplusKeyManage, request); // TODO 是否需要记录交易流水 // 1.2mac计算 byte[] iso_8583_main = requestEntity.pack(); byte[] input = ArrayUtils.subarray(iso_8583_main, 6, iso_8583_main.length - 8); // 去除body head byte[] macKey = CodecUtils.hex2byte(ulinkplusKeyManage.getTrmnlMacKey()); // byte[] mac = MacUtils.tCountMAC_CBC(input, macKey); // input = ArrayUtils.subarray(iso_8583_main, 0, iso_8583_main.length-8); // iso_8583_main = ArrayUtils.addAll(input, mac); byte[] mac; try { mac = CodecUtils.hex2byte(hsmService.calculateMAC_LOCALLIFE(macKey, input)); input = ArrayUtils.subarray(iso_8583_main, 0, iso_8583_main.length - 8); iso_8583_main = ArrayUtils.addAll(input, mac); } catch (HSMException e) { String hsmRespCode = XPOSPClientUtils.getCode(e); if (!AppExCode.UNKNOWN.equals(hsmRespCode)) { hsmRespCode = Const.TP_BEGIN_HSM + hsmRespCode; } logger.error( "ulinkplus credicard fee query failed,when calculate mac form hsm error code[" + hsmRespCode + "]"); throw new TransferFailedException( hsmRespCode, "ulinkplus credicard fee query failed,when calculate mac form hsm error code[" + hsmRespCode + "]"); } // 1.3组装报文报文头 byte[] iso_8583_body = ArrayUtils.addAll( XPOSPClientUtils.getTpduHeader(XpospSysProperty.getUlinkPlusQmf1TPDU()).pack(), iso_8583_main); String iso_8583_body_length = StringUtils.leftPad(Integer.toHexString(iso_8583_body.length), 4, "0"); byte[] iso_8583_length = ISOUtils.hex2byte(iso_8583_body_length); byte[] iso_8583 = ArrayUtils.addAll(iso_8583_length, iso_8583_body); // 2.发送报文 byte[] respData = TCPUtils.getInstance().sendReciveMsg(iso_8583, XpospSysProperty.getUlinkPlusQMFIP_PORT()); // 3.解析报文 UlinkplusResponseInfo response = new UlinkplusResponseInfo(); try { CreditcardFeeQueryTradeResponseEntity responseEntity = unpack(respData); // CreditcardFeeQueryTradeResponseEntity responseEntity = getResponseData(null); String isoRespCode = responseEntity.getRespCode(); if (!Const.ISO_RESPCODE_OK.equals(isoRespCode)) { isoRespCode = XPOSPClientUtils.getRespCode(isoRespCode); isoRespCode = Const.TP_BEGIN_ISO + StringUtils.leftPad("" + Integer.parseInt(isoRespCode), 3, "0"); logger.info( "pay via ulinkplus failed,iso error code[" + responseEntity.getRespCode() + "]"); throw new TransferFailedException( isoRespCode, "pay via ulinkplus failed,iso error code[" + responseEntity.getRespCode() + "]"); } // 响应 try { String selfDefined48 = new String(responseEntity.getSelfDefined48(), "GBK"); logger.debug("信用卡还款手续费查询,48域信息:" + selfDefined48); // 位置 长度 格式 内容 说明 // 0 2 n2 用法标志 “PA” // 2 2 n2 帐单号码类型 08 // 4 12 n12 还款总金额 右对齐,左补空格 // 16 12 n12 手续费 右对齐,左补空格 // 28 12 n12 还款金额 右对齐,左补空格 // 40 100 Ans100 终端提示信息 左对齐,右补空格 // 140 11 N11 手机号码 左对齐,右补空格 // 151 1 ans1 结束标志 # response.setFee( StringUtils.amtToBigDecimal(StringUtils.trimToEmpty(selfDefined48.substring(16, 28))) .toPlainString()); response.setMsgTip( StringUtils.trimToEmpty(selfDefined48.substring(40, selfDefined48.length() - 12))); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } } catch (RuntimeException e) { // 更新终端流水 cupsTrmnlService.updateCupsTrmnlFlowNo(cupsTrmnl); throw e; } logger.info("ulinkplus渠道手机充值结束..."); return response; }
public PepsiColaResponseInfo process( CupsTrmnl cupsTrmnl, CupsKeyManage cupsKeyManage, PepsiColaRequestInfo request) throws TransferFailedException { logger.info("[PepsiCola渠道IC卡脚本上送开始...]"); // 1.组装报文 IcScriptUploadTradeRequestEntity requestEntity = packUp(cupsTrmnl, cupsKeyManage, request); // iso mac计算 byte[] iso_8583_main = requestEntity.pack(); byte[] input = ArrayUtils.subarray(iso_8583_main, 6, iso_8583_main.length - 8); byte[] macKey = CodecUtils.hex2byte(cupsKeyManage.getTrmnlMacKey()); byte[] mac; try { mac = hsmService.calculateMAC_CUPS(macKey, input).getBytes(); input = ArrayUtils.subarray(iso_8583_main, 0, iso_8583_main.length - 8); iso_8583_main = ArrayUtils.addAll(input, mac); } catch (HSMException e) { String hsmRespCode = XPOSPClientUtils.getCode(e); if (!AppExCode.UNKNOWN.equals(hsmRespCode)) { hsmRespCode = Const.TP_BEGIN_HSM + hsmRespCode; } logger.error("[IC卡脚本上送失败,calculate mac form hsm error code:" + hsmRespCode + "]"); throw new TransferFailedException( hsmRespCode, "[IC卡脚本上送失败, 加密机计算MAC失败, errorCode:" + hsmRespCode + "]"); } // 组装报文报文头 byte[] iso_8583_body = ArrayUtils.addAll( XPOSPClientUtils.getTpduHeader(XpospSysProperty.getPepsiColaTPDU()).pack(), iso_8583_main); String iso_8583_body_length = StringUtils.leftPad(Integer.toHexString(iso_8583_body.length), 4, "0"); byte[] iso_8583_length = ISOUtils.hex2byte(iso_8583_body_length); byte[] iso_8583 = ArrayUtils.addAll(iso_8583_length, iso_8583_body); // 新增银联CUPS流水记录 {2,3,4,11,22,25,26,35,36,41,42,49,52,53,60,64} String payNo = transRefNoGenerator.generate(); PayCups payCups = new PayCups(); payCups.setPayNo(payNo); payCups.setCardNo(requestEntity.getCardNo()); payCups.setProcessCode(requestEntity.getProcessCode()); payCups.setTrmnlFlowNo(requestEntity.getTrmnlFlowNo()); payCups.setTrmnlBatchNo(cupsTrmnl.getTrmnlBatchNo()); payCups.setPosEntryMode(requestEntity.getPosEntryMode()); payCups.setCardSeqNum(request.getCardSeqNum()); payCups.setTrmnlNo(requestEntity.getTrmnlNo()); payCups.setTrmnlMrchNo(requestEntity.getTrmnlMrchNo()); payCups.setCurrency(requestEntity.getCurrency()); payCups.setIcData(request.getEmvTransInfo()); payCups.setSelfDefined060(requestEntity.getSelfDefined60()); payCups.setOriginalInfo(requestEntity.getOriginalMessage()); payCups.setTransType(TransType.ICSCRIPTUPLOAD.getOrdinal()); payCups.setSubChannel(SubChannelType.PEPSICOLATRANSFERCHANNEL.getChannelName()); payCupsService.addPayCups(payCups); // 打包,新增流水记录后更新终端流水信息 cupsTrmnlService.updateCupsTrmnlFlowNo(cupsTrmnl); // 2.发送报文 byte[] respData = TCPUtils.getInstance().sendReciveMsg(iso_8583, XpospSysProperty.getPepsiColaIP_PORT()); // 3.解析报文 PepsiColaResponseInfo pepsiColaResponseInfo = new PepsiColaResponseInfo(); try { IcScriptUploadTradeResponseEntity responseEntity = unpack(respData); String isoRespCode = responseEntity.getRespCode(); if (!Const.ISO_RESPCODE_OK.equals(isoRespCode)) { payCups.setRespCode(isoRespCode); isoRespCode = isoRespCode.replace("A", "10"); payCupsService.updatePayCups(payCups); isoRespCode = Const.TP_BEGIN_ISO + StringUtils.leftPad("" + Integer.parseInt(isoRespCode), 3, "0"); logger.error("[pay via cups failed, iso error code:" + isoRespCode + "]"); throw new TransferFailedException( isoRespCode, "[pay via cups failed, so error code:" + isoRespCode + "]"); } // 更新交易流水 payCups.setTransDate(responseEntity.getTransDate()); payCups.setTransTime(responseEntity.getTransTime()); payCups.setSettlementDate(responseEntity.getSettlementDate()); payCups.setRespCode(responseEntity.getRespCode()); payCupsService.updatePayCups(payCups); pepsiColaResponseInfo.setTransCode( Const.TP_BEGIN_ISO + StringUtils.leftPad("" + Integer.parseInt(isoRespCode), 3, "0")); // 响应 } catch (RuntimeException e) { throw e; } logger.info("[PepsiCola渠道IC卡脚本上送结束...]"); return pepsiColaResponseInfo; }