欢迎使用 Alipay Easy SDK for .NET 。
Alipay Esay SDK for .NET让您不用复杂编程即可访支付宝开放平台开放的各项常用能力,SDK可以自动帮您满足能力调用过程中所需的证书校验、加签、验签、发送HTTP请求等非功能性要求。
下面向您介绍Alipay Easy SDK for .NET 的基本设计理念和使用方法。
不同于原有的Alipay SDK通用而全面的设计理念,Alipay Easy SDK对开放能力的API进行了更加贴近高频场景的精心设计与裁剪,简化了服务端调用方式,让调用API像使用语言内置的函数一样简便。
Alipay Easy SDK提供了与能力地图相对应的代码组织结构,让开发者可以快速找到不同能力对应的API。
Alipay Easy SDK主要目标是提升开发者在服务端集成支付宝开放平台开放的各类核心能力的效率。
-
Alipay Easy SDK for .NET基于
.Net Standard 2.0
开发,支持.Net Framework 4.6.1
、.Net Core 2.0
及其以上版本 -
使用 Alipay Easy SDK for .NET 之前 ,您需要先前往支付宝开发平台-开发者中心完成开发者接入的一些准备工作,包括创建应用、为应用添加功能包、设置应用的接口加签方式等。
-
准备工作完成后,注意保存如下信息,后续将作为使用SDK的输入。
- 加签模式为公钥证书模式时(推荐)
AppID
、应用的私钥
、应用的公钥证书文件
、支付宝公钥证书文件
、支付宝根证书文件
- 加签模式为公钥模式时
AppId
、应用的私钥
、支付宝公钥
通过NuGet程序包管理器在线安装依赖(推荐)
-
在
解决方案资源管理器面板
中右击您的项目选择管理 NuGet 程序包
菜单,在打开的NuGet 管理面板
中点击浏览
选项卡输入AlipayEasySDK
,在下方列表中选择Authors
为antopen
由官方发布的最新稳定版NuGet包,点击 安装 即可。 -
或者通过 .NET CLI 工具来安装
dotnet add package AlipayEasySDK
- 使用
Visual Studio
打开本README.md
所在文件夹下的AlipayEasySDK.sln
解决方案,在生成
菜单栏下,执行全部重新生成
。 - 在
AlipayEasySDK/bin/Debug
或AlipayEasySDK/bin/Release
目录下,找到AlipayEasySDK.[version].nupkg
文件,该文件即为本SDK的NuGet离线包。 - 参照NuGet离线安装程序包使用指南,在您的.NET应用项目工程中引入本SDK的NuGet离线包,即可完成SDK的依赖安装。
以下这段代码示例向您展示了使用Alipay Easy SDK for .NET调用一个API的3个主要步骤:
- 设置参数(全局只需设置一次)。
- 发起API调用。
- 处理响应或异常。
using System;
using Alipay.EasySDK.Factory;
using Alipay.EasySDK.Kernel;
using Alipay.EasySDK.Payment.Models;
namespace SDKDemo
{
class Program
{
static void Main(string[] args)
{
// 1. 设置参数(全局只需设置一次)
Factory.SetOptions(GetConfig());
try
{
// 2. 发起API调用(以支付能力下的统一收单交易创建接口为例)
AlipayTradeCreateResponse response = Factory.Payment().Create("Apple iPhone11 128G",
"2234567890", "5799.00", "2088002656718920");
// 3. 处理响应或异常
if ("10000".Equals(response.Code))
{
Console.WriteLine("调用成功");
}
else
{
Console.WriteLine("调用失败,原因:" + response.Msg + "," + response.SubMsg);
}
}
catch (Exception ex)
{
Console.WriteLine("调用遭遇异常,原因:" + ex.Message);
throw ex;
}
}
static private Config GetConfig()
{
return new Config()
{
Protocol = "https",
GatewayHost = "openapi.alipay.com",
SignType = "RSA2",
// 请更换为您的AppId
AppId = "2019091767145019",
// 请更换为您的应用公钥证书文件路径
MerchantCertPath = "/home/foo/appCertPublicKey_2019051064521003.crt",
// 请更换为您的支付宝公钥证书文件路径
AlipayCertPath = "/home/foo/alipayCertPublicKey_RSA2.crt",
// 请更换为您的支付宝根证书文件路径
AlipayRootCertPath = "/home/foo/alipayRootCert.crt",
// 请更换为您的PKCS1格式的应用私钥
MerchantPrivateKey = "MIIEvQIBADANB ... ...",
// 如果采用非证书模式,则无需赋值上面的三个证书路径,改为赋值如下的支付宝公钥字符串即可
// AlipayPublicKey = "MIIBIjANBg..."
};
}
}
}
在Alipay Easy SDK中,API的引用路径与能力地图的组织层次一致,遵循如下规则
Factory.能力名称.[场景名称.]接口方法名称( ... )
比如,如果您想要使用能力地图中营销能力
下的模板消息
场景中的小程序发送模板消息
,只需调用Factory.Marketing.TemplateMessage().Send( ... );
API即可。
接口方法名称通常是对其依赖的OpenAPI功能的一个最简概况,接口方法的出入参数通常与OpenAPI中同名参数含义一致,参照OpenAPI相关参数的使用说明即可。Alipay Easy SDK将致力于保持良好的API命名,以符合开发者的编程直觉。
能力类别 | 场景类别 | 接口方法名称 | 调用的OpenAPI名称 |
---|---|---|---|
Base | OAuth | getToken | alipay.system.oauth.token |
Base | OAuth | refreshToken | alipay.system.oauth.token |
Base | Qrcode | create | alipay.open.app.qrcode.create |
Base | Image | upload | alipay.offline.material.image.upload |
Base | Video | upload | alipay.offline.material.image.upload |
Member | Identification | init | alipay.user.certify.open.initialize |
Member | Identification | certify | alipay.user.certify.open.certify |
Member | Identification | query | alipay.user.certify.open.query |
Payment | Common | create | alipay.trade.create |
Payment | Common | query | alipay.trade.query |
Payment | Common | refund | alipay.trade.refund |
Payment | Common | close | alipay.trade.close |
Payment | Common | cancel | alipay.trade.close |
Payment | Huabei | create | alipay.trade.create |
Payment | FaceToFace | pay | alipay.trade.pay |
Security | TextRisk | detect | alipay.security.risk.content.detect |
Marketing | Pass | createTemplate | alipay.pass.template.add |
Marketing | Pass | updateTemplate | alipay.pass.template.update |
Marketing | Pass | addInstance | alipay.pass.instance.add |
Marketing | Pass | updateInstance | alipay.pass.instance.update |
Marketing | TemplateMessage | send | alipay.open.app.mini.templatemessage.send |
Marketing | OpenLife | createImageTextContent | alipay.open.public.message.content.create |
Marketing | OpenLife | modifyImageTextContent | alipay.open.public.message.content.modify |
Marketing | OpenLife | sendText | alipay.open.public.message.total.send |
Marketing | OpenLife | sendImageText | alipay.open.public.message.total.send |
Marketing | OpenLife | sendSingleMessage | alipay.open.public.message.single.send |
Marketing | OpenLife | recallMessage | alipay.open.public.life.msg.recall |
Marketing | OpenLife | setIndustry | alipay.open.public.template.message.industry.modify |
Marketing | OpenLife | getIndustry | alipay.open.public.setting.category.query |
注:更多高频场景的API持续更新中,敬请期待。