欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.Net?7.0實現(xiàn)支付寶退款和結果查詢接口

 更新時間:2024年07月30日 09:11:54   作者:橙子家  
支付寶對 .Net 的支持還是比較充分的,在每個接口文檔中都有關于 C# 語言的示例,這樣就大大降低了對接的難度,很容易上手,這篇文章主要介紹了支付寶退款和結果查詢接口簡單實現(xiàn)(.Net?7.0),需要的朋友可以參考下

〇、前言

支付寶對 .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 必要賬戶基礎信息

名稱示例
應用 ID2024 ... ...(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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論