轻量易用的微信Sdk发布——Magicodes.Wx.Sdk

概述


最简洁最易于使用的微信Sdk,包括公众号Sdk、小程序Sdk、企业微信Sdk等,以及Abp VNext集成。

名称Nuget
Magicodes.Wx.PublicAccount.Sdk
Magicodes.Wx.PublicAccount.Sdk.AspNet
Magicodes.Wx.PublicAccount.Sdk.Abp

如何贡献?


如何快速封装一个微信接口?(30秒即可编写一个微信Api,欢迎多多PR)

如何快速定义一个微信上传文件的接口?

具体请访问Github:https://github.com/xin-lai/Magicodes.Wx.Sdk

RoadMap


公众号

  "Wx": {"PublicAccount": {"AppId": "","AppSecret": ""}}


快速上手


本Sdk上手非常简单,参考教程如下所示。

01

安装包

Install-Package Magicodes.Wx.PublicAccount.Sdk.AspNet

推荐使用此包,亦可使用Magicodes.Wx.PublicAccount.Sdk来进行更多的自定义配置。

02

基础配置

  • 配置文件配置

公众号的参考配置如下所示,请在appsettings.json文件中进行配置:

  "Wx": {"PublicAccount": {"AppId": "","AppSecret": ""}
  • 通过代码配置

参考代码如下所示:

 app.UseMagicodesWeChatSdk(setup =>{setup.GetWeChatOptions = () =>{//配置return new WxPublicAccountOption(){AppId = "",AppSecret = ""};};});

03

配置Sdk

参考代码如下所示:

   public void ConfigureServices(IServiceCollection services){//添加公众号Sdk集成services.AddMPublicAccountSdk()//使用内存缓存.AddDistributedMemoryCache();}public void Configure(IApplicationBuilder app){//配置公众号Sdkapp.UseMPublicAccountSdk()//使用分布式缓存缓存Access Token.UseWxDistributedCacheForAccessToken();}

04

调用Api

接下来就简单了,通过依赖注入的方式注入相关Api,比如构造函数注入:

    public HomeController(IMenuApi menuApi){_menuApi = menuApi;}

然后就可以使用了,如下面代码:

        var result = await _menuApi.CreateAsync(new CreateMenuInput(){Button = new List<MenuButtonBase>(){new ClickButton(){Name = "今日歌曲",Key = "V1001_TODAY_MUSIC"},new SubMenuButton(){Name = "菜单",SubButtons = new List<MenuButtonBase>(){new ViewButton(){Name = "搜索",Url = "http://www.soso.com/"},//需关联小程序后//new MiniprogramButton()//{//    Name = "wxa",//    Url = "http://mp.weixin.qq.com",//    AppId = "wx286b93c14bbf93aa",//    Pagepath = "pages/lunar/index"//},new ClickButton(){Name = "赞一下我们",Key = "V1001_GOOD"}}}}}); result.EnsureSuccess();

微信服务器事件、消息处理和被动消息回复


如何处理微信服务器事件、消息,步骤如下所示:

01

配置Sdk

nuget包的安装和公众号的配置我们这里跳过,直接秀出Sdk配置代码:

  public void ConfigureServices(IServiceCollection services){//注册IWxEventsHandler,如需处理自定义事件消息,请务必实现IWxEventsHandlerservices.AddSingleton<IWxEventsHandler, TestWxEventsHandler>();services.AddMPublicAccountSdk().AddDistributedMemoryCache()//添加服务器消息事件处理器.AddServerMessageHandler();}public void Configure(IApplicationBuilder app){//配置公众号Sdkapp.UseMPublicAccountSdk()//使用分布式缓存缓存Access Token.UseWxDistributedCacheForAccessToken();}

02

实现IWxEventsHandler

参考代码如下所示:

/// <summary>
/// 公众号事件消息处理程序
/// </summary>
public class TestWxEventsHandler : IWxEventsHandler
{/// <summary>/// 执行/// </summary>/// <param name="fromMessage"></param>/// <returns></returns>public async Task<ToMessageBase> Execute(IFromMessage fromMessage){if (fromMessage is FromTextMessage){//返回多图文var toMsg = new ToNewsMessage(){Articles = new List<ToNewsMessage.ArticleInfo>(){new ToNewsMessage.ArticleInfo(){Description = "最简洁最易于使用的微信Sdk,包括公众号Sdk、小程序Sdk、企业微信Sdk等,以及Abp VNext集成。",PicUrl = "https://www.xin-lai.com/imgs/xinlai-logo_9d2c29c2794e6a173738bf92b056ab69.png",Title="Magicodes.Wx.Sdk简介",Url = "http://xin-lai.com"}},FromUserName = "Test",ToUserName = "Test"};return await Task.FromResult(toMsg);}else if (fromMessage is FromSubscribeEvent){//返回文本消息return await Task.FromResult(new ToTextMessage(){Content = "欢迎关注!",});}else if (fromMessage is FromTextMessage){//返回文本return await Task.FromResult(new ToTextMessage(){Content = "Test",});}return await Task.FromResult(new ToNullMessage());}
}

相关事件和消息以及消息回复的定义,如下所示:

  • 事件推送

    • 关注事件:FromSubscribeEvent

    • 取消关注事件:FromUnsubscribeEvent

    • 扫码事件:FromScanEvent

    • 地理位置选择器事件:FromLocationEvent

    • 点击事件:FromClickEvent

    • 点击菜单链接跳转事件:FromViewEvent

    • 模板消息推送完成事件:FromTemplateSendJobFinishEvent

    • 点击菜单跳转小程序事件:FromViewMiniprogramEvent

  • 基础消息

    • 文本消息:FromTextMessage

    • 图片消息:FromImageMessage

    • 语音消息:FromVoiceMessage

    • 视频消息:FromVideoMessage

    • 小视频消息:FromShortVideoMessage

    • 地理位置消息:FromLocationMessage

    • 链接消息:FromLinkMessage

  • 被动消息回复

    • 回复文本消息:ToTextMessage

    • 回复图片消息:ToImageMessage

    • 回复语音消息:ToVoiceMessage

    • 回复视频消息:ToVideoMessage

    • 回复音乐消息:ToMusicMessage

    • 回复图文消息:ToNewsMessage

    • 回复空消息(不回复):ToNullMessage


MVC网页授权


在ASP.NET MVC,我们可以通过本SDK快速获得微信用户信息,参考代码如下所示:

//注意继承WxPublicAccountControllerBase
public class HomeController : WxPublicAccountControllerBase
{private readonly ILogger<HomeController> _logger;public HomeController(ILogger<HomeController> logger){_logger = logger;}//设置了WxPublicAccountOAuthFilter的Action在缓存过期的情况下,将自动跳转到微信网页授权页面进行授权//OAuthLevel设置为OpenIdAndUserInfo允许获取粉丝信息[WxPublicAccountOAuthFilter(OAuthLevel = OAuthLevels.OpenIdAndUserInfo)]public async Task<IActionResult> IndexAsync(){//调用父级控制器的获取粉丝信息方法,该方法从ISnsApi中获取粉丝详细信息var userResult = await GetWeChatUserInfoAsync();var model = new UserInfo(){Headimgurl = userResult.Headimgurl,NickName = userResult.NickName,Sex = userResult.Sex};_logger.LogDebug($"NickName:{userResult.NickName}");return View(model);}
}

Abp VNext集成


Magicodes.Wx.PublicAccount.Sdk默认提供了Abp VNext模块,相关步骤如下所示:

01

安装Magicodes.Wx.PublicAccount.Sdk.Abp

Install-Package Magicodes.Wx.PublicAccount.Sdk.Abp

02

添加模块依赖

[DependsOn(typeof(WxPublicAccountSdkModule)
)]

如需处理服务器事件消息,还需注册IWxEventsHandler:

context.Services.AddSingleton<IWxEventsHandler, WxEventsHandler>();

联系我们


01

文档官网

https://docs.xin-lai.com/

02

博客

http://www.cnblogs.com/codelove/

03

其他开源库

  • https://github.com/xin-lai

  • https://gitee.com/magicodes

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/303969.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数学界的高冷之王,N次拒绝巨额奖金:我穷,但是我不缺钱。。。

在现实生活中&#xff0c;你和谁在一起的确很重要&#xff0c;甚至能改变你的成长轨迹&#xff0c;决定你的人生成败。是否还记得&#xff0c;当你跟学霸做同学的时候&#xff0c;你总会莫名其妙跟他一起撸题目&#xff1b;当宿舍其他兄弟正在打游戏的时候&#xff0c;你也想着…

php-7.1.0,PHP 7.4.0 Alpha 1 v7.4.0 官方最新版

PHP团队近期宣布推出PHP 7.4.0首个版本PHP 7.4.0 Alpha 1&#xff0c;且下一个Alpha 2版本也在计划推出&#xff0c;不过作为早期测试版本&#xff0c;建议不要在生产环境中使用&#xff0c;想体验PHP最新运行逻辑的可以下载体验PHP 7.4.0 Alpha 1源码。基本简介PHP原始为Perso…

算法分析的正确姿势

一、前言在进一步学习数据结构与算法前&#xff0c;我们应该先掌握算法分析的一般方法。算法分析主要包括对算法的时空复杂度进行分析&#xff0c;但有些时候我们更关心算法的实际运行性能如何&#xff0c;此外&#xff0c;算法可视化是一项帮助我们理解算法实际执行过程的实用…

浏览器缓存机制的研究分享

源宝导读&#xff1a;互联网Web应用大行其道的今天&#xff0c;浏览器已经成为Web应用运行的重要平台。而Web应用对浏览器缓存机制的高效利用&#xff0c;可以大幅提升应用性能和用户体验。本文将对浏览器缓存机制进行系统化的梳理&#xff0c;分享我们的经验。一、背景计算机读…

Windows2008应用之配置客户端自动添加打印机

打印机对我们每一个人来说都是习以为常的东西了&#xff0c;给你一条远程打印机共享路径&#xff0c;你只要轻轻的双击想安装的打印机图标&#xff0c;等上个三五秒打印机就安装好&#xff0c;这台打印机就任你摆布了。但相对我们IT人员来说&#xff0c;全面的自动化将是我们的…

现代CSS进化史

英文&#xff1a;Peter Jang 编译&#xff1a;缪斯segmentfault.com/a/1190000013191860CSS一直被web开发者认为是最简单也是最难的一门奇葩语言。它的入门确实非常简单——你只需为元素定义好样式属性和值&#xff0c;看起来似乎需要做的工作也就这样嘛&#xff01;然而在一些…

一日一技:Ocelot网关使用IdentityServer4认证

概述Ocelot是一个用.NET Core实现的开源API网关技术。IdentityServer4是一个基于OpenID Connect和OAuth2.0的针对ASP.NET Core的框架&#xff0c;以中间件的形式存在。OAuth是一种授权机制。系统产生一个短期的token&#xff0c;用来代替密码&#xff0c;供第三方应用使用。下面…

php windows共享内存,关于php的共享内存的使用和研究之由起

最近遇到一个场景&#xff0c;服务寻址的时候&#xff0c;需要请求远程的服务&#xff0c;获取一批可用的ip和端口地址及其权重。根据权重和随机算法选择最合适的一个服务地址&#xff0c;进行请求。由于服务地址在短时间之内不会发生变化&#xff0c;因此为了避免无限制的进行…

联想继续为其硬件产品完善Linux支持

喜欢就关注我们吧&#xff01;此前&#xff0c;联想曾宣布为其台式机/笔记本电脑预装 Fedora/Ubuntu 等 Linux 发行版。并通过与 RedHat 等达成合作&#xff0c;为 Linux 带来了更多的上游工作支持。时至今日&#xff0c;据 Phoronix 称&#xff0c;自联想开始提供 Linux 预装以…

Excel有哪些需要熟练掌握而很多人不会的技能!

看完这篇Excel攻略&#xff0c;你会感觉这么多年的excel都白学了&#xff01;来自知乎用户“未央之末”的分享。从今年年初的excel盲&#xff0c;到现在经常从大拿那偷师&#xff0c;也算是成长了不少&#xff0c;慢慢写下来算是对学习excel做个短期回顾——1排版篇给他人发送e…

如何在 ASP.NET Core 中使用 LazyCache

微软的 ASP.NET Core 已经是一个非常流行的用于构建 高性能, 模块化 并能运行在 Windows, Linux, MacOS 上的 WEB 框架&#xff0c;通常能够让程序保持高性能的一个有效途径就是通过缓存热链上的数据来应对高频的请求。LazyCache 是一款基于内存的易于使用和线程安全的缓存组件…

2018全球大学AI排名发布,中国高校表现强势!

[导读] 近日&#xff0c;麻省理工学院马萨诸塞校区计算机与信息科学学院教授 Emery Berger 发布一个全球院校计算机科学领域实力排名的开源项目 CSranking 更新了。目前&#xff0c;卡耐基梅隆大学&#xff08;CMU&#xff09;、麻省理工学院&#xff08;MIT&#xff09;与斯坦…

在C#中使用 CancellationToken 处理异步任务

在 .NET Core 中使用异步编程已经很普遍了&#xff0c; 你在项目中随处可见 async 和 await&#xff0c;它简化了异步操作&#xff0c;允许开发人员&#xff0c;使用同步的方式编写异步代码&#xff0c;你会发现在大部分的异步方法中&#xff0c;都提供了CancellationToken参数…

通过Python实现马尔科夫链蒙特卡罗方法的入门级应用

通过把马尔科夫链蒙特卡罗&#xff08;MCMC&#xff09;应用于一个具体问题&#xff0c;本文介绍了 Python 中 MCMC 的入门级应用。GitHub 地址&#xff1a;https://github.com/WillKoehrsen/ai-projects/blob/master/bayesian/bayesian_inference.ipynb过去几月中&#xff0c;…

315曝光不良奸商 对企业不能罚酒三杯

3月15日&#xff0c;315晚会又曝光了一批无良奸商&#xff0c;虽然315晚会年年曝光&#xff0c;各地政府也迅速跟进打击&#xff0c;但侵害消费者权益的情况却屡见不鲜。从被曝光企业的道歉信来看&#xff0c;“承认错误只是个别问题全面排查整改配合管理部门执法向消费者表示道…

.NET 产品版权保护方案 (.NET源码加密保护)

一. 前言大家好&#xff0c;我是康世杰&#xff0c;大家可以叫我Jason。我和大家一样&#xff0c;都是搞技术出身&#xff0c;也未当过讲师&#xff0c;所以口材有限&#xff0c;如果讲得不好之处&#xff0c;还希望大家多多海含&#xff0c;谢谢。今天是我们第一次见面&…

java地图 热力图,腾讯地图数据可视化之热力图

前言数据可视化API(Web)&#xff0c;是基于腾讯位置服务JavaScript API GL实现的专业地理空间数据可视化渲染引擎。 通过这套API&#xff0c;可以实现轨迹数据、坐标点数据、热力、迁徙、航线等空间数据的可视化展现。使用步骤1、注册成为腾讯位置服务开发者&#xff0c;并进入…

建模分析师与算法工程师的主要区别

大家晚上好&#xff0c;我是新来的实习生小模君&#xff0c;前几天小智老师给我科普了数据挖掘的基础知识&#xff0c;颇有收获&#xff0c;于是就趁小天今天有事休假冒个泡跟大家分享一番。数据挖掘&#xff0c;英文名叫Data mining&#xff0c;一般是指从大型数据库中将隐藏的…

Flurl使用Polly实现重试Policy

❝在使用Flurl作为HttpClient向Server请求时&#xff0c;由于网络或者其它一些原因导致请求会有失败的情况&#xff0c;比如HttpStatusCode.NotFound、HttpStatusCode.ServiceUnavailable、HttpStatusCode.RequestTimeout等&#xff1b;网络上有比较多的HttpClientFactory使用P…

推荐15个 JavaScript 和 CSS 库

Tutorialzine的使命是让开发者与最新的Web开发发展同步。因此&#xff0c;我们每月都会精选一批最优秀的资源推荐给大家&#xff0c;相信这些资源你绝对值得拥有&#xff01;ClarifyJSClarifyJS可以让你串联一串方法&#xff0c;以任意顺序执行。通常的JavaScript方法是从左到右…