当前位置:首页 > 软件开放 > 正文内容

微信网站开发源代码(微信网站开发源代码是什么)

软件开放6个月前 (07-08)414

缘起

今年公司某个项目需要全面接入微信支付 V3 版 API。起初觉得,2014 年微信支付就已上线了 V3 版 API,这都 2021 年了,就算官方不给力,怎么着社区也该有几个造好的 .NET 的轮子了吧?于是兴冲冲地到 NuGet 上开始搜索“微信支付”四个大字,结果……

倒不是没有现成的轮子,但基本都是只包含一些简单 API(如下单、查单、退款等等),与需求不符;偶尔有一些看似封装全的,点进去一看却是基于 V2 版 API 的。

没办法,自己动手,丰衣足食!

接入了微信支付后想着,既然微信支付都有了,为啥不把公众号、小程序、企业微信之类的也接入了呢?

于是乎 SKIT.FlurlHttpClient.Wechat 这个项目就诞生了。

项目介绍

SKIT.FlurlHttpClient.Wechat 是一个基于 Flurl.Http 的微信 API HTTP 客户端。

包含以下特性:

支持 .NET Framework 4.6.1+、.NET Standard 2.0+、.NET Core 2.0+、.NET 5。

支持 Windows / Linux / macOS 多平台部署。

支持 System.Text.Json(默认)和 Newtonsoft.Json 两种序列化方式。

异步式编程。

强类型接口模型。

提供拦截器功能。

提供微信 API 所需的 MD5、SHA-1、SHA-256、AES、RSA 等算法工具类。

完整、完善、完全的微信 API 封装,同时可灵活自行扩展。

现有以下模块:

公众平台(公众号、小程序、小游戏、小商店) 开放平台模块: SKIT.FlurlHttpClient.Wechat.Api

商户平台(微信支付)模块: SKIT.FlurlHttpClient.Wechat.TenpayV3

企业微信(企业号)模块: SKIT.FlurlHttpClient.Wechat.Work

广告平台(广点通)模块: SKIT.FlurlHttpClient.Wechat.Ads

以接入微信支付为例,其他模块的开发流程与之十分类似。

安装: dotnet add package SKIT.FlurlHttpClient.Wechat.TenpayV3

初始化:

usingSKIT.FlurlHttpClient.Wechat;

usingSKIT.FlurlHttpClient.Wechat.TenpayV3;

usingSKIT.FlurlHttpClient.Wechat.TenpayV3.Settings;

/* 平台证书管理器,具体用法请参见文档 */

varcertManager = newInMemoryCertificateManager;

/* 仅列出必须配置项。也包含一些诸如超时时间、UserAgent 等的配置项 */

varoptions = newWechatTenpayClientOptions

{

MerchantId = "微信商户号",

MerchantV3Secret = "微信商户 v3 API 密钥",

MerchantCertSerialNumber = "微信商户证书序列号",

MerchantCertPrivateKey = "-----BEGIN PRIVATE KEY-----微信商户证书私钥-----END PRIVATE KEY-----",

CertificateManager = certManager

};

varclient = newWechatTenpayClient(options);

usingSKIT.FlurlHttpClient.Wechat.TenpayV3;

usingSKIT.FlurlHttpClient.Wechat.TenpayV3.Models;

/* 以 JSAPI 统一下单接口为例 */

varrequest = newCreatePayTransactionJsapiRequest

{

微信网站开发源代码(微信网站开发源代码是什么)

OutTradeNumber = "商户订单号",

AppId = "微信 AppId",

Deion = "订单描述",

ExpireTime = DateTimeOffset.Now.AddMinutes(15),

NotifyUrl = "https://example.com",

Amount = newCreatePayTransactionJsapiRequest.Types.Amount

{

Total = 100

},

Payer = newCreatePayTransactionJsapiRequest.Types.Payer

{

OpenId = "微信 OpenId"

}

};

varresponse = awaitclient.ExecuteCreatePayTransactionJsapiAsync(request);

if(response.IsSuccessful)

{

Console.WriteLine( "PrepayId:"+ response.PrepayId);

}

else

{

Console.WriteLine( "HTTP 状态:"+ response.RawStatus);

Console.WriteLine( "错误代码:"+ response.ErrorCode);

Console.WriteLine( "错误描述:"+ response.ErrorMessage);

}

展开全文

/* 一般情况下可以跳过验证响应的签名 */

boolvalid = client.VerifyResponseSignature(response);

/* 字典结构,包含客户端 JS-SDK 调起支付所需的完整参数 */

varparamMap = client.GenerateParametersForJsapiPayRequest(request.AppId, response.PrepayId);

stringcallbackJson = "{ 微信商户平台发来的 JSON 格式的通知内容 }";

stringcallbackTimestamp = "微信回调通知中的 Wechatpay-Timestamp 标头";

stringcallbackNonce = "微信回调通知中的 Wechatpay-Nonce 标头";

stringcallbackSignature = "微信回调通知中的 Wechatpay-Signature 标头";

stringcallbackSerialNumber = "微信回调通知中的 Wechatpay-Serial 标头";

boolvalid = client.VerifyEventSignature(callbackTimestamp, callbackNonce, callbackJson, callbackSignature, callbackSerialNumber);

if(valid)

{

/* 将 JSON 反序列化得到通知对象 */

/* 你也可以将 WechatTenpayEvent 类型直接绑定到 MVC 模型上,这样就不再需要手动反序列化 */

varcallbackModel = client.DeserializeEvent(callbackJson);

if( "TRANSACTION.SUCCESS".Equals(callbackModel.EventType))

{

/* 根据事件类型,解密得到支付通知敏感数据 */

varcallbackResource = client.DecryptEventResourceEvents.TransactionResource(callbackModel);

stringoutTradeNumber = callbackResource.OutTradeNumber;

stringtransactionId = callbackResource.TransactionId;

Console.WriteLine( "订单 {0} 已完成支付,交易单号为 {1}", outTradeNumber, transactionId);

}

}

更多使用说明请阅读项目仓库中的开发文档。

项目仓库中还包含了一个示例项目,以供开发者快速掌握本库的使用方法。

FAQ 1. Flurl.Http 是什么?

Flurl.Http 是一个轻量级 HTTP 库,是 .NET 中最受欢迎扩展库之一,在 NuGet 上的累计下载量超过 1700 万、日均下载量超过 6 千、GitHub 2.6k Stars(数据统计截至 2021-06-01)。

与另一个流行的 HTTP 库 RestSharp 相比, Flurl.Http 底层基于 System.Net.Http.HttpClient ,而 RestSharp 底层则基于 System.Net.HttpWebRequest ,前者在多核多线程环境下的性能基准测试中表现要远优于后者,同时也是微软官方目前推荐的 HTTP 客户端方案。

2. 本库与盛派微信 SDK(Senparc.Weixin)有什么区别?

本库 专注于 API 本身的封装 ,捎带提供了一些用于加解密、序列化的工具类, 使用更灵活 ;盛派微信 SDK 提供了大而全的功能,可与 MVC / WebAPI 深度集成。

本库 遵循微软官方推荐的 C# 属性命名方式(大驼峰命名法) 对接口模型进行定义;盛派微信 SDK 提供的是微信接口本身的命名方式(蛇形命名法和小驼峰命名法混杂)。

本库 封装了目前微信官方提供的所有 API ;盛派微信 SDK 只提供了常用的 API。

直接原因是本库的依赖库最低支持到 .NET Framework 4.6.1。

间接原因是为了支持跨平台的 .NET Standard 2.0,只能兼容到 .NET Framework 4.6.1。

根本原因是微软官方已于 2016 年 1 月 12 日终止了对 .NET Framework 4.6.1 以下版本的技术支持。也就是说,微软已经不再为此提供安全更新,在大部分技术合规要求中这一点都是扣分项,所以建议各位开发者目标框架能升级就升级。

仓库

GitHub:https://github.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat

Gitee:https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat

以上仓库地址同步更新,均可接受 Issue 或 Pull Request。

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://chlfg.com/post/118052.html

分享给朋友:

“微信网站开发源代码(微信网站开发源代码是什么)” 的相关文章

牡丹江软件开发(牡丹江软件工程师招聘)

牡丹江软件开发(牡丹江软件工程师招聘)

今天给各位分享牡丹江软件开发的知识,其中也会对牡丹江软件工程师招聘进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、牡丹江宏博软件开发有限公司怎么样? 2、牡丹江哪有教软件开发Java的培训班 3、牡丹江蓝崎软件开发有限责任公司怎么样? 牡丹江宏博软...

一对一直播软件开发(一对一直播软件开发平台)

一对一直播软件开发(一对一直播软件开发平台)

本篇文章给大家谈谈一对一直播软件开发,以及一对一直播软件开发平台对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、在网上的一对一直播软件开发,一搬情况下需要多少钱? 2、一对一直播App开发,需要了解哪些核心 3、一对一视频聊天软件找哪个开发好? 4、一对一直播...

qrs间期正常值是多少(qrs时间为多少正常值)

qrs间期正常值是多少(qrs时间为多少正常值)

本篇文章给大家谈谈qrs间期正常值是多少,以及qrs时间为多少正常值对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、请问p/QRS/T电轴正常是多少 2、心电图正常值 3、心电图的p-R间期正常值是多少? 请问p/QRS/T电轴正常是多少 哦,从数据上看还是正常...

魔域交易猫手游交易平台(魔域端游账号交易平台)

魔域交易猫手游交易平台(魔域端游账号交易平台)

今天给各位分享魔域交易猫手游交易平台的知识,其中也会对魔域端游账号交易平台进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、交易猫平台主要的作用是什么? 2、手游交易平台哪个好 3、十大手游交易平台排行榜 交易猫平台主要的作用是什么? 交易猫主要是一...

sony相机官方售后电话(sony相机客服电话)

sony相机官方售后电话(sony相机客服电话)

今天给各位分享sony相机官方售后电话的知识,其中也会对sony相机客服电话进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、索尼相机合肥售后服务在哪里 2、哈尔滨的索尼相机售后服务在哪 3、襄阳SONY相机的售后服务电话是多少?地址在哪? 索尼相机...

手机搬砖游戏赚钱的手游2022(2021能搬砖赚人民币的手游)

手机搬砖游戏赚钱的手游2022(2021能搬砖赚人民币的手游)

本篇文章给大家谈谈手机搬砖游戏赚钱的手游2022,以及2021能搬砖赚人民币的手游对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、2022年4月14日最靠谱良心手游赚现金版有那些 2、赚钱手游排行榜2022 3、适合一台手机搬砖的手游 2022年4月14日最靠谱...