1. 程式人生 > >Java微信支付開發之關閉訂單

Java微信支付開發之關閉訂單

官方文件

一、應用場景

  • 商戶訂單支付失敗需要生成新單號重新發起支付,要對原訂單號呼叫關單,避免重複支付
  • 系統下單後,使用者支付超時,系統退出不再受理,避免使用者繼續,請呼叫關單介面
注意:訂單生成後不能馬上呼叫關單介面,最短呼叫時間間隔為5分鐘。

二、介面地址

https://api.mch.weixin.qq.com/pay/closeorder

三、請求引數

只能根據自己商戶系統的訂單號關閉

package com.phil.wechatpay.model.rep;

import java.io.Serializable;

/**
 * 關閉訂單請求引數(正常XML)
 * @author phil
 * @date  2017年7月25日
 *
 */
public class CloseOrderParams extends AbstractPayParams implements Serializable{
	
	/**
	 * 
	 */
	private static final long serialVersionUID = -4206464928803827244L;
	
	private String out_trade_no; //商戶訂單號 
	
	public String getOut_trade_no() {
		return out_trade_no;
	}

	public void setOut_trade_no(String out_trade_no) {
		this.out_trade_no = out_trade_no;
	}
}

四、返回結果

package com.phil.wechatpay.model.resp;

import java.io.Serializable;

import com.phil.common.annotation.NotRequire;

/**
 * 關閉訂單返回引數(帶<![CDATA[]]>XML格式)
 * 
 * @author phil
 * @date 2017年7月25日
 *
 */
public class CloseOrderResult extends AbstractPayResult implements Serializable {
	
	private static final long serialVersionUID = -1996103742747816922L;
	private String return_code; // 返回狀態碼SUCCESS/FAIL
	@NotRequire
	private String return_msg; //返回資訊

	/**** return_code 為SUCCESS ****/
	private String result_code;// 業務結果
	private String result_msg;// 業務結果描述	
	@NotRequire
	private String err_code;// 錯誤返回的資訊描述
	@NotRequire
	private String err_code_des;// 錯誤返回的資訊描述
}

五、關閉訂單

package com.phil.wechatpay.controller;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.phil.common.config.WechatConfig;
import com.phil.common.util.HttpReqUtil;
import com.phil.common.util.PayUtil;
import com.phil.common.util.SignatureUtil;
import com.phil.common.util.XmlUtil;
import com.phil.wechatpay.model.rep.CloseOrderParams;
import com.phil.wechatpay.model.resp.CloseOrderResult;
import com.phil.wechatpay.service.WechatPayService;

/**
 * 關閉訂單
 * @author phil
 * @date  2017年7月25日
 *
 */
@Controller
@RequestMapping("/wxpay/")
public class WechatPayCloseOrderController {
	
	@Autowired
	private WechatPayService wechatPayService;
	
	@ResponseBody
	@RequestMapping("closeOrder")
	public CloseOrderResult closeOrder(HttpServletRequest request, HttpServletResponse response) throws Exception {
		CloseOrderResult closeOrderResult = null;
		CloseOrderParams closeOrderParams = new CloseOrderParams();
		closeOrderParams.setAppid(WechatConfig.APP_ID);
		closeOrderParams.setMch_id(WechatConfig.MCH_ID);
		closeOrderParams.setNonce_str(PayUtil.createNonceStr());
		closeOrderParams.setOut_trade_no("");//自己傳入
		//請求的xml
		String closeOrderXml = wechatPayService.abstractPayToXml(closeOrderParams);//簽名合併到service
		// 返回<![CDATA[SUCCESS]]>格式的XML
		String closeOrderResultXmL = HttpReqUtil.HttpsDefaultExecute(HttpReqUtil.POST_METHOD,WechatConfig.CLOSE_ORDER_URL, null, closeOrderXml);
		// 進行簽名校驗
		if (SignatureUtil.checkIsSignValidFromWeiXin(closeOrderResultXmL)) {
			closeOrderResult = XmlUtil.getObjectFromXML(closeOrderResultXmL, CloseOrderResult.class);
		}
		return closeOrderResult;
	}
}