java对接银联商务公众号+服务窗支付(5)

java实现银联商务公众号+服务窗对接----订单撤销

本文对接银联商务公众号+服务窗支付,实现支付下单订单查询订单退款退款查询和订单关闭几个功能,使用到银联商务的公众+服务窗支付接口规范,请自行百度下载。
在上几篇支付下单下单查询订单退款退款查询,已经实现公众号下单支付、下单查询、订单退款、退款查询功能的实现和接口的封装,本篇将介绍订单撤销的对接实现,并将我使用到的银联商务的请求接口和响应接口进行封装,使用测试网页输出测试信息。
一、接口及代码实现
1.订单撤销接口
1.1接口规范
接口规范请查看下载的银联商务公众号+服务窗接口规范订单撤销接口部分,这里不做展示。
1.2 代码实现
1.2.1 CloseOrderController代码

/**
  * 订单关闭接口
  * @param request
  * @param response
  * @param merOrderId
  * @return
  * @throws UnsupportedEncodingException
  */
 @RequestMapping(value = "/OrderClose", method = RequestMethod.POST)
// public Map<String, Object> close(HttpServletRequest request, HttpServletResponse response, String merOrderId) throws UnsupportedEncodingException {  
//  Map<String,Object> map = new HashMap<String,Object>(); //接收退款请求map
//  map.put("merOrderId", merOrderId); //商户订单号
//  Map<String, Object> closeordermap = closeorderserviceimpl.CloseOrder(map);
//  logger.info("closeordermap = " + closeordermap);
//  return closeordermap; //返回refundmap
// }
 
 public Map<String, Object> close(HttpServletRequest request, HttpServletResponse response, @RequestBody String jsonreq) throws UnsupportedEncodingException {  
  Map<String,Object> map = new HashMap<String,Object>();    //接收退款查询请求map
  Map<String,Object> reqmap = new HashMap<String,Object>();  //客户端原始请求map
  Map<String,Object> datamap = new HashMap<String,Object>();  //客户端原始请求Data数据
  Map<String,Object> resultmap = new HashMap<String,Object>(); //返回结果
  //接收客户端请求数据并转换成map
  reqmap = JsonUtils.JsonToMapObj(jsonreq);
  logger.info("unifiedquery reqmap = " + reqmap);
  
  datamap = (Map<String, Object>) reqmap.get("tradeParam"); //请求体数据
  logger.info("unifiedquery datamap = " + datamap);
  
  //-----------------------step1  验证签名-----------------------------
  String sign = (String) reqmap.get("sign");  //获取sign
  String key = UnionPayConstants.GGMD5KEY;  //国光MD5密钥
  try {
   if (!PayUtil.verifySign(datamap,key,sign)) {
    resultmap.put("returnCode", "Bad_Sign");
    resultmap.put("returnInfo", "签名错误");
    return resultmap;
   }
  //-----------------------step2  验证消息类型  tradeType:close-------------
   if (!"close".equals(reqmap.get("tradeType"))) {
    resultmap.put("returnCode", "TradeType_Error");
    resultmap.put("returnInfo", "消息类型不符");
    return resultmap;
   }
  //------------------------step3验证传参完整性---------------------------
   //验证公共参数完整性
   if(!PayUtil.verifyParameter(datamap)) {
    resultmap.put("returnCode", "Common_Value_Error");
    resultmap.put("returnInfo", "缺少必要公共参数");
    return resultmap;
   }
   //验证接口参数完整性
   if(datamap.get("merOrderId").equals("")) {
    resultmap.put("returnCode", "Value_Error");
    resultmap.put("returnInfo", "缺少必要接口参数");
    return resultmap;
   }
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
   resultmap.put("returnCode", "System_Error");
   resultmap.put("returnInfo", "系统异常");
   return resultmap;
  }
  //------------------------step4 传值并调用退款查询接口----------------------
  map.put("mid", datamap.get("mid"));         //商户号
  map.put("tid", datamap.get("tid"));      //终端号
  map.put("instMid", datamap.get("instMid"));    //机构商户号
  map.put("msgSrc", datamap.get("msgSrc"));    //消息来源
  map.put("merOrderId", datamap.get("merOrderId"));  //原商户订单号
  Map<String, Object> closeordermap = closeorderserviceimpl.CloseOrder(map);
  logger.info("closeordermap = " + closeordermap);
  
  if(!"200".equals(closeordermap.get("statuscode"))) {
   resultmap.put("returnCode", "Union_Connect_Error");
   resultmap.put("returnInfo", "银联网付连接失败");
   return resultmap;
  }
  //------------------------step5接口返回数据------------------------------
  Map<String,Object> resultdatamap = new HashMap<String,Object>();  //resultmap中data数据
  resultdatamap.put("errCode", closeordermap.get("errCode"));    //平台错误码
  resultdatamap.put("status", closeordermap.get("status"));    //交易状态
  resultdatamap.put("totalAmount", closeordermap.get("totalAmount"));  //退款金额
  resultdatamap.put("targetSys", closeordermap.get("targetSys"));   //目标平台代码(第三方代码)
  resultdatamap.put("targetStatus", closeordermap.get("targetStatus")); //目标平台状态
  resultdatamap.put("messageType", closeordermap.get("msgType"));    //消息类型
  
  resultmap.put("data", resultdatamap);
  resultmap.put("returnCode", closeordermap.get("errCode")); 
  //resultmap.put("returnInfo", refundquerymap.get("errMsg"));
 
  return resultmap; //返回map
 }

1.2.2 closeorderserviceimpl代码

本部分代码为银联商务公众号订单撤销服务实现类。

@Override
 public Map<String, Object> CloseOrder(Map<String, Object> map) throws UnsupportedEncodingException {
  // TODO Auto-generated method stub
  
  logger.info("------------------close order--------------------------");
  Map<String, Object> reqmap = new HashMap<String, Object>(); //请求map
  Map<String, Object> resp = new HashMap<String, Object>(); //响应resp
  reqmap.put("mid", map.get("mid").toString());    //1商户号
  reqmap.put("tid", map.get("tid").toString());    //2终端号
  reqmap.put("instMid", map.get("instMid").toString());  //3业务类型
  reqmap.put("msgSrc", map.get("msgSrc").toString());   //4消息来源    
  reqmap.put("msgType", "close");        //5消息类型
  
  String aligetTime = PayUtil.aligetTime();
  logger.info("请求时间aligetTime = " + aligetTime);
  reqmap.put("requestTimestamp", aligetTime);     //6报文请求时间 
  reqmap.put("merOrderId", map.get("merOrderId").toString()); //7原交易订单号
  
  //生成待签名字符串并进行MD5加密
  String builderSignStr = "";
  try {
     builderSignStr = PayUtil.builderSignStr(reqmap,UnionPayConstants.MD5KEY);
   //signString = PayUtil.generateSignature(reqmap, UnionPayConstants.MD5KEY);
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  reqmap.put("sign", builderSignStr.toLowerCase());       //8签名,转小写
  logger.info("reqmap= " + reqmap);
  
  String jsonstring = GGitUtil.MapToJson2(reqmap); //请求map转成json string
  logger.info("发送CloseOrder post请求消息:" + jsonstring);
  
  //接收银联商务返回map
  resp = unionpayrequest.dopost(UnionPayConstants.queryURL, jsonstring);
  return resp;
 }

1.3测试结果

本文对所写接口写了测试网页进行测试,如图所示。封装的银联商务响应接口中,输入的商户订单号为已支付订单号,响应结果中显示的是OPTION_NOT_ALLOWED,查看银联商务接口文档,表示此订单号已被支付,为关闭状态。(实际测试中,由于参数为测试环境参数,订单关闭接口测试会出现没有配置API的错误,需要连接生产环境,生产环境参数暂时没有下来。)
在这里插入图片描述

《中国移动通信CMPP2.0短消息网关开发接口库》 本接口是用VC6.0遵循中国移动通信标准CMPP2.0协议开发的短消息网关接口,目的是简化SP接入移动短消息网关的复杂度。 本接口对网络通信和CMPP2.0协议进行了高度封,连接过所有类型的移动网关,暂时不支持CMPPE(东软格式,但东软也支持标准CMPP). 本接口还提供了网关的部分功能接口,可以很方便地用来开发模拟网关),接口库就提供了一个功能完整的模拟网关源码!接口包含两个示例工程,一个是客户端,通过CMPP2.0连接网关,演示了登录、MT、MO的全过程;一个就是模拟网关,可以接收用户的登录,接收MT请求,同时还可以主动批量下发MO消息。 更新历史: 2003-08-08 V1.3 1. 增加了对cmpp_recv函数的返回值CMPP_RECVTIMEOUT的说明。 2. 修改了cmpp_login_value_set()函数,去掉了一个参数。 2003-07-23 V1.22 1.增加了两个函数(cmpp_submit_sm_set_msgsrc和cmpp_submit_sm_set_srctermid),可以分别用来设置Src_Id和Msg_src。 根据移动的要求(升级后的网关),sp下发消息时,Src_Term_Id和Msg_src必须为该连接的对端的SP的服务代码和企业代码 (见《关于SP下发数据格式的规范》). 2003-07-08 V1.2 1.修正了cmpp_login_value_set函数的一个bug。 2003-06-07 V1.1 1.增加了网关接收部分的接口,同时新增了详细使用手册和模拟网关的源码,并且在真实环境中测试通过! 2003-04-25 V1.0 1.0发布。 作者: princetoad Email:princetoad@tom.com Homepage:http://gmm.nease.net 1.3版下载地址:http://gmm.nease.net/CMPP.rar 1.22版下载地址:http://skybird.9s9s.com/upload/upfile/2003723956540.rar 1.21版下载地址:http://www.csdn.net/cnshare/soft/17/17025.shtm 1.2版下载地址:http://skybird.9s9s.com/upload/upfile/2003781329230.rar 1.1版下载地址:http://www.vckbase.com/code/listcode.asp?mclsid=9&sclsid=917 本接口库有偿提供源码,请到中国共享软件注册中心注册或联系作者,princetoad@tom.com。 注册地址:http://www.softreg.com.cn/shareware.asp?id=11530 同时提供中国联通SGIP1.2接口库,更多详情请访问作者主页! 下载:http://gmm.nease.net/SGIP.rar 注册地址:http://www.softreg.com.cn/shareware.asp?id=11517
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值