经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » ASP.net » 查看文章
支付宝退款和结果查询接口简单实现(.Net 7.0)
来源:cnblogs  作者:橙子家  时间:2024/7/31 14:59:55  对本文有异议

〇、前言

支付宝对 .Net 的支持还是比较充分的,在每个接口文档中都有关于 C# 语言的示例,这样就大大降低了对接的难度,很容易上手。

官方接口文档地址:退款-alipay.trade.refund  退款状态查询-alipay.trade.fastpay.refund.query 

本文就简单实现下这两个接口,并顺便记录特别注意的点。

一、接入准备

1.1 引入 SDK

安装支付宝开放平台官方 SDK:AlipaySDKNet.Standard。基于.Net Standard 2.0开发,支持.Net Framework 4.6.1、.Net Core 2.0及其以上版本。

NuGet 简介地址:https://www.nuget.org/packages/AlipaySDKNet.Standard/

1.2 必要账户基础信息

名称 示例  
应用 ID 2024 ... ... (15 位纯数字)
应用公钥 MIIBIjANBgkqhk ... ... (392 位)
应用私钥 MIIEvgIBADANBgk ... ... (PKCS1 格式的 1592 位)

注意:通过支付宝密钥工具生成的应用私钥默认是 PKCS8 格式的,仅适用于 Java,此时必须手动转换成 PKCS1 格式,适用于其他全部语言。

密钥工具下载地址:https://opendocs.alipay.com/common/02kipk

如下格式转换,下边为转换后的格式以及标注:

二、接口调用

2.1 公用配置方法

将固定的应用信息填入,此方法可在不同接口中公用:

  1. private static AlipayConfig GetAlipayConfig()
  2. {
  3. string privateKey = "<-- 请填写您的应用私钥,例如:MIIEvQIBADANB ... ... -->";
  4. string alipayPublicKey = "<-- 请填写您的支付宝公钥,例如:MIIBIjANBg... -->";
  5. AlipayConfig alipayConfig = new AlipayConfig();
  6. alipayConfig.ServerUrl = "https://openapi.alipay.com/gateway.do";
  7. alipayConfig.AppId = "<-- 请填写您的AppId,例如:2019091767145019 -->";
  8. alipayConfig.PrivateKey = privateKey;
  9. alipayConfig.Format = "json";
  10. alipayConfig.AlipayPublicKey = alipayPublicKey;
  11. alipayConfig.Charset = "UTF-8";
  12. alipayConfig.SignType = "RSA2";
  13. return alipayConfig;
  14. }

2.2 退款接口

以下是退款接口的代码,其中入参仅示例了必要的字段,其他详情见官方文档。

  1. // 初始化SDK
  2. IAopClient alipayClient = new DefaultAopClient(GetAlipayConfig());
  3. // 构造请求参数以调用接口
  4. AlipayTradeRefundRequest request = new AlipayTradeRefundRequest();
  5. AlipayTradeRefundModel model = new AlipayTradeRefundModel();
  6. // 设置查询选项
  7. List<String> queryOptions = new List<String>();
  8. queryOptions.Add("refund_detail_item_list");
  9. model.QueryOptions = queryOptions;
  10. //// 设置商户订单号(与支付宝交易号,配置任一即可)
  11. //model.OutTradeNo = "20150320010101001";
  12. // 设置支付宝交易号
  13. model.TradeNo = "2024072900000000000000000001";
  14. // 设置退款金额,单位为:元
  15. model.RefundAmount = "0.01";
  16. // 设置退款原因说明
  17. model.RefundReason = "正常退款0729";
  18. // 设置退款请求号
  19. model.OutRequestNo = $"ZFB{DateTime.Now.ToString("yyyyMMddHHmmssffffff")}";
  20. request.SetBizModel(model);
  21. AlipayTradeRefundResponse response = alipayClient.Execute(request);
  22. if (!response.IsError)
  23. {
  24. Console.WriteLine("调用成功");
  25. }
  26. else
  27. {
  28. Console.WriteLine("调用失败");
  29. }

成功返回:

  1. {
  2. "alipay_trade_refund_response": {
  3. "code": "10000",
  4. "msg": "Success",
  5. "buyer_logon_id": "188******10",
  6. "fund_change": "Y",
  7. "gmt_refund_pay": "2024-07-29 13:50:04",
  8. "out_trade_no": "*****",
  9. "refund_detail_item_list": [
  10. {
  11. "amount": "0.01",
  12. "fund_channel": "COUPON"
  13. }
  14. ],
  15. "refund_fee": "0.01",
  16. "send_back_fee": "0.01",
  17. "trade_no": "*****",
  18. "buyer_open_id": "*****"
  19. },
  20. "sign": "*****"
  21. }

2.3 退款状态查询接口

以下是退款状态查询接口的代码,其中入参仅示例了必要的字段,其他详情见官方文档。

  1. // 初始化SDK
  2. IAopClient alipayClient = new DefaultAopClient(GetAlipayConfig());
  3. // 构造请求参数以调用接口
  4. AlipayTradeFastpayRefundQueryRequest request = new AlipayTradeFastpayRefundQueryRequest();
  5. AlipayTradeFastpayRefundQueryModel model = new AlipayTradeFastpayRefundQueryModel();
  6. // 设置查询选项
  7. List<String> queryOptions = new List<String>();
  8. queryOptions.Add("refund_detail_item_list");
  9. model.QueryOptions = queryOptions;
  10. //// 设置商户订单号(与支付宝交易号,配置任一即可)
  11. //model.OutTradeNo = "2014112611001004680073956707";
  12. // 设置支付宝交易号
  13. model.TradeNo = "2024072900000000000000000001";
  14. // 设置退款请求号,来自退款接口中生成的编号
  15. model.OutRequestNo = "ZFB20240729135000591024";
  16. request.SetBizModel(model);
  17. AlipayTradeFastpayRefundQueryResponse response = alipayClient.Execute(request);
  18. if (!response.IsError)
  19. {
  20. Console.WriteLine("调用成功");
  21. }
  22. else
  23. {
  24. Console.WriteLine("调用失败");
  25. }

成功返回:

  1. {
  2. "alipay_trade_fastpay_refund_query_response": {
  3. "code": "10000",
  4. "msg": "Success",
  5. "out_request_no": "ZFB20240729135000591024",
  6. "out_trade_no": "*****",
  7. "refund_amount": "0.01",
  8. "refund_detail_item_list": [
  9. {
  10. "amount": "0.01",
  11. "fund_channel": "COUPON"
  12. }
  13. ],
  14. "refund_status": "REFUND_SUCCESS",
  15. "send_back_fee": "0.01",
  16. "total_amount": "1.00",
  17. "trade_no": "*****"
  18. },
  19. "sign": "*****"
  20. }

原文链接:https://www.cnblogs.com/hnzhengfy/p/18330730/alipay_refunds

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号