open-pdd-net-sdk,拼多多开放平台 DotNet SDK。
遇到任何问题可通过底部联系方式反馈,作者会第一时间进行处理!
更新文档已经迁移到CHANGELOG.md
。
支持基于 NETStandardv2.0 的项目,支持 .NetFramework 4.5.2+,C#7.1。
ASP.NET Core 项目请使用 Nuget 包 MSDev.PddOpenSdk.AspNetCore
,可直接通过注入服务的方式使用。
其他类型使用 Nuget 包 MSDev.PddOpenSdk
。
该项目是可以遍历并自动生成所有请求模型类、返回模型类以及请求服务类,生成后部分会有重名,更改即可。
支持 .Net Framework4.5.2
及Net Standard 2.0
,安装 Nuget 包 MSDev.PddOpenSdk
。
使用示例:
class Program
{
static async Task Main(string[] args)
{
// 先使用code换取token
string code = "";
var authApi = new AuthApi();
await authApi.GetAccessTokenAsync(code);
// 设置ClientId与ClientSecret
PddCommonApi.ClientId = "ID";
PddCommonApi.ClientSecret = "Secret";
// 构造请求内容
var model = new GenDdkWeappQrcodeUrlRequestModel
{
PId = "123133",
GoodsIdList = new System.Collections.Generic.List<long> { 1122, 331323 }
};
var api = new DdkApi();
var result = await api.GenDdkWeappQrcodeUrlAsync(model);
}
}
先安装Nuget 包 MSDev.PddOpenSdk.AspNetCore
。
可参考示例代码
- 在 Startup.cs 中注入服务
services.AddPdd(options =>
{
// 使用appsettings 配置你的ClientId等参数
options.ClientId = Configuration.GetSection("Pdd")["ClientId"];
options.CallbackUrl = Configuration.GetSection("Pdd")["RedirectUri"];
options.ClientSecret = Configuration.GetSection("Pdd")["ClientSecret"];
});
- 然后在控制器使用注入服务
readonly PddService _pdd;
public YourController(PddService pdd)
{
_pdd = pdd;
}
- 获取 AccessToken
/// <summary>
/// 测试获取token
/// </summary>
/// <param name="code"></param>
/// <returns></returns>
public async Task<IActionResult> Callback(string code)
{
var token = await _pdd.AuthApi.GetAccessTokenAsync(code);
// 自行维护Token过期时间
return Content(token.AccessToken);
}
-
调用其他接口
获取 AccessToken 之后才能正常调用其他接口。
public async Task<ActionResult> Test()
{
// 构造请求模型
var requestModel = new SearchDdkGoodsRequestModel
{
SortType = 0,
WithCoupon = false
};
// 调用相应接口方法
var result = await _pdd.DdkApi.SearchDdkGoodsAsync(requestModel);
return Content(JsonConvert.SerializeObject(result));
}
所有方法名与官方文档保持一致,并有中文注释提醒,只是更改了命名规范,非常容易查找使用。
- 签名错误问题,主要检查一下时间戳的获取是否正确。
- 由于拼多多官方文档中存在一些问题,可能会有一些返回模型是有问题的,无法正确解析到类型,导致没有正确返回数据!遇到这类问题,可直接修改源代码,提交代码合并申请;或者直接找作者反馈。
欢迎通过以下方式反馈问题:
- 提交 GitHub Issues(优先处理)
- Email: zpty@outlook.com
- QQ 群:737822525