微信撤销订单java,Java微信支付之关闭订单

本文详细介绍了如何使用Java实现微信支付的关闭订单功能,包括接口调用、请求参数和返回结果解析。通过调用微信支付API,商户可以对超时未支付的订单进行关闭,防止重复支付。需要注意的是,关闭订单接口需要在订单创建后至少等待5分钟才能调用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文实例为大家分享了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;

/**

* 关闭订单返回参数(带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

// 返回格式的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;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值