.Net?7.0實現(xiàn)支付寶退款和結果查詢接口
〇、前言
支付寶對 .Net 的支持還是比較充分的,在每個接口文檔中都有關于 C# 語言的示例,這樣就大大降低了對接的難度,很容易上手。
官方接口文檔地址:退款-alipay.trade.refund 退款狀態(tài)查詢-alipay.trade.fastpay.refund.query
本文就簡單實現(xiàn)下這兩個接口,并順便記錄特別注意的點。
一、接入準備
1.1 引入 SDK
安裝支付寶開放平臺官方 SDK:AlipaySDKNet.Standard?;?Net Standard 2.0開發(fā),支持.Net Framework 4.6.1、.Net Core 2.0及其以上版本。
NuGet 簡介地址:https://www.nuget.org/packages/AlipaySDKNet.Standard/
1.2 必要賬戶基礎信息
名稱 | 示例 | |
應用 ID | 2024 ... ... | (15 位純數(shù)字) |
應用公鑰 | MIIBIjANBgkqhk ... ... | (392 位) |
應用私鑰 | MIIEvgIBADANBgk ... ... | (PKCS1 格式的 1592 位) |
注意:通過支付寶密鑰工具生成的應用私鑰默認是 PKCS8 格式的,僅適用于 Java,此時必須手動轉換成 PKCS1 格式,適用于其他全部語言。
密鑰工具下載地址:https://opendocs.alipay.com/common/02kipk
如下格式轉換,下邊為轉換后的格式以及標注:
二、接口調(diào)用
2.1 公用配置方法
將固定的應用信息填入,此方法可在不同接口中公用:
private static AlipayConfig GetAlipayConfig() { string privateKey = "<-- 請?zhí)顚懩膽盟借€,例如:MIIEvQIBADANB ... ... -->"; string alipayPublicKey = "<-- 請?zhí)顚懩闹Ц秾毠€,例如:MIIBIjANBg... -->"; AlipayConfig alipayConfig = new AlipayConfig(); alipayConfig.ServerUrl = "https://openapi.alipay.com/gateway.do"; alipayConfig.AppId = "<-- 請?zhí)顚懩腁ppId,例如:2019091767145019 -->"; alipayConfig.PrivateKey = privateKey; alipayConfig.Format = "json"; alipayConfig.AlipayPublicKey = alipayPublicKey; alipayConfig.Charset = "UTF-8"; alipayConfig.SignType = "RSA2"; return alipayConfig; }
2.2 退款接口
以下是退款接口的代碼,其中入?yún)?strong>僅示例了必要的字段,其他詳情見官方文檔。
// 初始化SDK IAopClient alipayClient = new DefaultAopClient(GetAlipayConfig()); // 構造請求參數(shù)以調(diào)用接口 AlipayTradeRefundRequest request = new AlipayTradeRefundRequest(); AlipayTradeRefundModel model = new AlipayTradeRefundModel(); // 設置查詢選項 List<String> queryOptions = new List<String>(); queryOptions.Add("refund_detail_item_list"); model.QueryOptions = queryOptions; //// 設置商戶訂單號(與支付寶交易號,配置任一即可) //model.OutTradeNo = "20150320010101001"; // 設置支付寶交易號 model.TradeNo = "2024072900000000000000000001"; // 設置退款金額,單位為:元 model.RefundAmount = "0.01"; // 設置退款原因說明 model.RefundReason = "正常退款0729"; // 設置退款請求號 model.OutRequestNo = $"ZFB{DateTime.Now.ToString("yyyyMMddHHmmssffffff")}"; request.SetBizModel(model); AlipayTradeRefundResponse response = alipayClient.Execute(request); if (!response.IsError) { Console.WriteLine("調(diào)用成功"); } else { Console.WriteLine("調(diào)用失敗"); }
成功返回:
{ "alipay_trade_refund_response": { "code": "10000", "msg": "Success", "buyer_logon_id": "188******10", "fund_change": "Y", "gmt_refund_pay": "2024-07-29 13:50:04", "out_trade_no": "*****", "refund_detail_item_list": [ { "amount": "0.01", "fund_channel": "COUPON" } ], "refund_fee": "0.01", "send_back_fee": "0.01", "trade_no": "*****", "buyer_open_id": "*****" }, "sign": "*****" }
2.3 退款狀態(tài)查詢接口
以下是退款狀態(tài)查詢接口的代碼,其中入?yún)?strong>僅示例了必要的字段,其他詳情見官方文檔。
// 初始化SDK IAopClient alipayClient = new DefaultAopClient(GetAlipayConfig()); // 構造請求參數(shù)以調(diào)用接口 AlipayTradeFastpayRefundQueryRequest request = new AlipayTradeFastpayRefundQueryRequest(); AlipayTradeFastpayRefundQueryModel model = new AlipayTradeFastpayRefundQueryModel(); // 設置查詢選項 List<String> queryOptions = new List<String>(); queryOptions.Add("refund_detail_item_list"); model.QueryOptions = queryOptions; //// 設置商戶訂單號(與支付寶交易號,配置任一即可) //model.OutTradeNo = "2014112611001004680073956707"; // 設置支付寶交易號 model.TradeNo = "2024072900000000000000000001"; // 設置退款請求號,來自退款接口中生成的編號 model.OutRequestNo = "ZFB20240729135000591024"; request.SetBizModel(model); AlipayTradeFastpayRefundQueryResponse response = alipayClient.Execute(request); if (!response.IsError) { Console.WriteLine("調(diào)用成功"); } else { Console.WriteLine("調(diào)用失敗"); }
成功返回:
{ "alipay_trade_fastpay_refund_query_response": { "code": "10000", "msg": "Success", "out_request_no": "ZFB20240729135000591024", "out_trade_no": "*****", "refund_amount": "0.01", "refund_detail_item_list": [ { "amount": "0.01", "fund_channel": "COUPON" } ], "refund_status": "REFUND_SUCCESS", "send_back_fee": "0.01", "total_amount": "1.00", "trade_no": "*****" }, "sign": "*****" }
到此這篇關于支付寶退款和結果查詢接口簡單實現(xiàn)(.Net 7.0)的文章就介紹到這了,更多相關.Net 支付寶退款和結果查詢接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用DataTable.Select 方法時,特殊字符的轉義方法分享
常見的特殊字符 基本都能轉義 ,不知道還有沒有漏掉的 ,目前使用正常 ,有需要的朋友可以參考一下2013-10-10Entity?Framework?Core實現(xiàn)Like查詢詳解
本文詳細講解了Entity?Framework?Core實現(xiàn)Like查詢的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02.net indexOf(String.indexOf 方法)
字符串的IndexOf()方法搜索在該字符串上是否出現(xiàn)了作為參數(shù)傳遞的字符串,如果找到字符串,則返回字符的起始位置 (0表示第一個字符,1表示第二個字符依此類推)如果說沒有找到則返回 -12012-10-10ASP.NET Repeater 單雙行數(shù)據(jù)換色示例
ASP.NET Repeater 單雙行數(shù)據(jù)換色根據(jù)點擊Repeater的ItemCreated觸發(fā)事件來時實現(xiàn)換色2014-10-10ASP.NET Core 導入導出Excel xlsx 文件實例
本篇文章主要介紹了ASP.NET Core 導入導出Excel xlsx 文件,非常具有實用價值,需要的朋友可以參考下。2016-12-12