微信支付之退款查询

2024-05-31 17:18
文章标签 查询 微信 支付 退款

本文主要是介绍微信支付之退款查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

应用场景

提交退款申请后,通过调用该接口查询退款状态。退款有一定延时,用零钱支付的退款20分钟内到账,银行卡支付的退款3个工作日后重新查询退款状态。

官方文档: http://pay.weixin.qq.com/wiki/doc/api/index.php?chapter=9_5

参考代码:

package com.wingo.action.config;

 

import java.util.Map;

import java.util.SortedMap;

import java.util.TreeMap;

 

import com.wingo.util.CommonUtil;

import com.wingo.util.ConfigUtil;

import com.wingo.util.PayCommonUtil;

import com.wingo.util.XMLUtil;

 

/**

 *

 * @author李欣桦

 * @date 2015-1-15下午2:00:49

 * 退款查询

 */

publicclassCheckRefundAction {

   publicstaticvoid main(String[] args) throws Exception {

       SortedMap<Object,Object> parameters = newTreeMap<Object,Object>();

       parameters.put("appid", ConfigUtil.APPID);

       parameters.put("mch_id", ConfigUtil.MCH_ID);

       //parameters.put("device_info","");//微信支付分配的终端设备号

       parameters.put("nonce_str", PayCommonUtil.CreateNoncestr());

       //下列四个单号同时存在优先级refund_id>out_refund_no>transaction_id>out_trade_no

       parameters.put("transaction_id", "1008010446201412030006459614");//微信交易单号

       parameters.put("out_trade_no", "1340297960");//商户交易单号

       parameters.put("out_refund_no", "");//商户退款单号

       parameters.put("refund_id", "");//微信退款单号

       

       String sign = PayCommonUtil.createSign("utf-8",parameters);

       parameters.put("sign", sign);

       String reuqestXml = PayCommonUtil.getRequestXml(parameters);

       

       String result =CommonUtil.httpsRequest(ConfigUtil.CHECK_REFUND_URL,"POST",reuqestXml);

       System.out.println(result);

       Map<String, String> map = XMLUtil.doXMLParse(result);

       String returnCode = map.get("return_code");

       String resultCode = map.get("result_code");

       if(returnCode.equalsIgnoreCase("SUCCESS")&&resultCode.equalsIgnoreCase("SUCCESS")){

          String refundCount = map.get("refund_count");

          Integer count = new Integer(refundCount);

          for (inti = 0; i < count; i++) {

            StringrefundStatus = (String) map.get("refund_status_"+i);

            //refudnStatus有如下状态:

            //SUCCES—退款成功,FAIL—退款失败,PROCESSING—退款处理中NOTSURE—未确定,需要商户原退款单号重新发起

            //CHANGE—转入代发,退款到银行发现用户的卡作废或者冻结了,导致原路退款银行卡失败,资金回流到商户的现金帐号,需要商户人工干

            //预,通过线下或者财付通转账的方式进行退款。

            if(refundStatus.equalsIgnoreCase("SUCCESS")){

                //TODO退款成功操作

                System.out.println("退款状态为已成功退款");

            }

           

          }

       }

   }

}


上述代码中相关工具类的下载地址如下:

http://download.csdn.net/detail/u011160656/8354883


这篇关于微信支付之退款查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1018553

相关文章

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE