轻量易用的微信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…

OneOfT1,…,Tn清新

OneOf——其中之一&#xff0c;这是一个泛型类&#xff0c;意思就是这里泛型中的任何一个类都可以&#xff0c;还是看代码吧。引入包install-package OneOf实现一个产品查询&#xff0c;有三种情况&#xff0c;查询到返回&#xff1b;查询不到&#xff1b;查询出错。[ApiContro…

VMware Workstation(虚拟机) V6.0.2 Build 59824 汉化版 |

【基本介绍】 VMWare是一个“虚拟PC”软件.它使你可以在一台机器上同时运行二个或更多Windows、DOS、LINUX系统。与“多启动”系统相 比,VMWare采用了完全不同的概念.多启动系统在一个时刻只能运行一个系统,在系统切换时需要重新启动机器.VMWare是真正“同时”运行&…

java导出 elsx 文件,如何获取java导出的excel文件,发送请求导出excle文件

如何获取java导出的excel文件1234567891011121314request.setCharacterEncoding("utf-8");String title request.getParameter("title");//title URLDecoder.decode(title,"utf-8");int maid Integer.parseInt(request.getParameter("ma…

算法分析的正确姿势

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

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

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

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

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

php数字转中文数字排序,php实现中文转数字

分享一个辅助函数&#xff0c;使用php尽可能识别出字符串中的数字&#xff0c;先上代码function checkNatInt($str) {$map array(一 > 1,二 > 2,三 > 3,四 > 4,五 > 5,六 > 6,七 > 7,八 > 8,九 > 9,壹 > 1,贰 > 2,叁 > 3,肆 > 4,伍 &g…

现代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;供第三方应用使用。下面…

影响你的人

在网上逛&#xff0c;总能碰上有价值的好东西&#xff1b;大一时&#xff0c;总认为网就是一个休闲消遣的东西&#xff0c;要学习编程&#xff0c;就是扎实的看书&#xff0c;练习&#xff0c;并给自己定下大学不连网的目标。在留校的暑假里&#xff0c;一头扎进电脑&#xff0…

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

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

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

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

算法面试:精选微软等公司经典的算法面试100题 第26-35题

算法面试&#xff1a;精选微软等公司经典的算法面试100题 第26-35题 26.左旋转字符串题目&#xff1a;定义字符串的左旋转操作&#xff1a;把字符串前面的若干个字符移动到字符串的尾部。如把字符串abcdef左旋转2位得到字符串cdefab。请实现字符串左旋转的函数。要求时间对长度…

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

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

java get请求简洁,java 实现 HTTP请求(GET、POST)的方法

使用Java进行服务调用时&#xff0c;避免不了要使用模拟HTTP请求来实现模拟&#xff0c;我在开发过程中恰巧遇到了这类的业务需求&#xff0c;所以就对这类的方法进行了一次总结&#xff0c;原理层次的东西暂时不考虑&#xff0c;毕竟HTTP的底层实现啥的&#xff0c;东西挺多且…

如何在 ASP.NET Core 中使用 LazyCache

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

伪装 php 版本号,linux伪装隐藏Nginx,PHP版本号提升服务器安全性

一、隐藏Nginx版本号第一步&#xff1a;vi /usr/local/nginx/conf/nginx.conf在http{}中加入server_tokens off;第二歩&#xff1a;vi /usr/local/nginx/conf/fastcgi_params将里面的fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;修改为&#xff1a;fastcgi_param SERV…

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

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