作者:王先荣

最近在学习微信公众号开发,将学习的成果做成了一个类库,方便重复使用。

现在微信公众号多如牛毛,开发微信的高手可以直接无视这个系列的文章了。

使用该类库的流程及寥寥数行代码得到的结果如下。

 

本文的源代码主要在:http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount/blob/master/xrwang.net/WeixinInterface.ashx以及http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount/blob/master/xrwang.net/Global.asax

1 引用微信公众号类库

引用xrwang.weixin.PublicAccount。

2 添加公众号信息

添加提供服务的公众号的信息,包括:原始id、AppId、AppSecret、EncodingAESKey。代码如下:

  1. AccountInfoCollection.SetAccountInfo(new AccountInfo("YourOriginalId", "AppId", "AppSecret", "Token", "EncodingAESKey"));

如果需要同时给多个公众号提供服务,重复上面这行代码就可以了。

注:由于微信服务器的原因,如果在一个站点中要同时给多个公众号提供服务,有两种方法:如果用同一页面处理多个公众号,那么Token必须一致(1)可以在接口配置信息的URL中加入区分公众号的参数(例如:http://www.xrwang.net/WeixinInterface.ashx?username=gh_5dbae931ec49);(2)针对每个公众号单独建立一个页面来处理。我目前采用了第一种方式,这样更简便。

我喜欢将添加公众号信息的工作放到Gobal.asax的Application_Start方法中。

3 与微信服务器通信

我添加了名为“WeixinInterface.ashx”的一般处理页,并在其中与微信服务器进行通信,包括:校验请求、处理请求、回复适当的响应。代码如下:

  1. public void ProcessRequest(HttpContext context)
  2.  
  3. {
  4.  
  5. string result = string.Empty;
  6.  
  7. if (Validate(context))
  8.  
  9. {
  10.  
  11. if (context.Request.HttpMethod == WebRequestMethods.Http.Get)
  12.  
  13. result = HandleGet(context);
  14.  
  15. else if (context.Request.HttpMethod == WebRequestMethods.Http.Post)
  16.  
  17. result = HandlePost(context);
  18.  
  19. }
  20.  
  21. else
  22.  
  23. Message.Insert(new Message(MessageType.Exception, "校验消息失败。\r\n地址:" + context.Request.RawUrl));
  24.  
  25. context.Response.Write(result);
  26.  
  27. }

与微信服务器通信

3.1 校验请求

首先,我们需要校验接收到的请求是否来自微信服务器,方法如下:

  1. /// <summary>
  2.  
  3. /// 验证消息的有效性
  4.  
  5. /// </summary>
  6.  
  7. /// <param name="context"></param>
  8.  
  9. /// <returns>如果消息有效,返回true;否则返回false。</returns>
  10.  
  11. private bool Validate(HttpContext context)
  12.  
  13. {
  14.  
  15. string token = AccountInfoCollection.First.Token; //由于在校验微信签名时,微信未传入公众号,因此这里用第一个公众号的TOKEN
  16.  
  17. string signature = RequestEx.TryGetQueryString("signature");
  18.  
  19. string timestamp = RequestEx.TryGetQueryString("timestamp");
  20.  
  21. string nonce = RequestEx.TryGetQueryString("nonce");
  22.  
  23. if (string.IsNullOrWhiteSpace(signature) || string.IsNullOrWhiteSpace(timestamp) || string.IsNullOrWhiteSpace(nonce))
  24.  
  25. return false;
  26.  
  27. return xrwang.weixin.PublicAccount.Utility.CheckSignature(signature, token, timestamp, nonce);
  28.  
  29. }

校验请求

当然,如果你对世界充满爱,相信没有欺骗;如果你厉行节约,急需提高性能;不校验也是可以的。

3.2 处理请求

校验完请求之后,我们分两种情况处理请求:

(1)微信服务器的GET请求,用来验证我们的服务器是否正在工作,我们直接返回echostr就可以了;

  1. /// <summary>
  2.  
  3. /// 处理微信的GET请求,校验签名
  4.  
  5. /// </summary>
  6.  
  7. /// <param name="context"></param>
  8.  
  9. /// <returns>返回echostr</returns>
  10.  
  11. private string HandleGet(HttpContext context)
  12.  
  13. {
  14.  
  15. return RequestEx.TryGetQueryString("echostr");
  16.  
  17. }

处理GET请求

(2)微信服务器的POST请求,这是服务器分发给我们的消息,我们需要解析消息。

  1. RequestMessageHelper helper = new RequestMessageHelper(context.Request);

3.3 回复响应

解析完微信服务器分发给我们的消息之后,我们要做出回应。我这里把收到的消息直接发回去,偷懒~\(≧▽≦)/~啦啦啦

  1. /// <summary>
  2.  
  3. /// 处理微信的POST请求
  4.  
  5. /// </summary>
  6.  
  7. /// <param name="context"></param>
  8.  
  9. /// <returns>返回xml响应</returns>
  10.  
  11. private string HandlePost(HttpContext context)
  12.  
  13. {
  14.  
  15. RequestMessageHelper helper = new RequestMessageHelper(context.Request);
  16.  
  17. if (helper.Message != null)
  18.  
  19. {
  20.  
  21. ResponseBaseMessage responseMessage = HandleRequestMessage(helper.Message);
  22.  
  23. return responseMessage.ToXml(helper.EncryptType);
  24.  
  25. }
  26.  
  27. else
  28.  
  29. return string.Empty;
  30.  
  31. }
  32.  
  33. /// <summary>
  34.  
  35. /// 处理请求消息,返回响应消息
  36.  
  37. /// </summary>
  38.  
  39. /// <returns>返回响应消息</returns>
  40.  
  41. private ResponseBaseMessage HandleRequestMessage(RequestBaseMessage requestMessage)
  42.  
  43. {
  44.  
  45. ResponseTextMessage response = new ResponseTextMessage(requestMessage.FromUserName, requestMessage.ToUserName,
  46.  
  47. DateTime.Now, string.Format("自动回复,请求内容如下:\r\n{0}", requestMessage));
  48.  
  49. response.Content += "\r\n<a href=\"http://www.cnblogs.com\">博客园</a>";
  50.  
  51. return response;
  52.  
  53. }

回复响应

当然了,正常情况下,我们需要兵来将挡水来土掩,根据不同的请求,回复对应的响应。如果需要对请求排队,再一一回复客服消息,可以先直接回复空字符串。回复客服消息的方法请看后面的文章。

4 微信公众号类库简介

xrwang.weixin.PublicAccount是一套简化微信公众号开发的类库,由王先荣开发,并且正在添砖加瓦中。采用MIT开源协议,大家可以随便用,别删掉我的名字就可以啦。

源代码的地址是:http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount

如果发现BUG,请在博客中留言,或者给我发电子邮件:xrwang(a)126.com。

千万不要用QQ或者阿里旺旺聊天,打扰我玩游戏,我会骂人的  >.<

5 体验测试号

下面分别是我的测试号和公众号,您可以对照文章来体验哦。

测试号

测试号权限多,几乎可以测试公众平台的所有功能。

我的公众号

xrwang

个人订阅号,功能较少,不过我会特别优化。

好了,感谢您看完本文,希望对您有所帮助。本文来自xrwang的博客http://xrwang/cnblogs.com,欢迎在不篡改作者的前提下转载以传播知识。

.net微信公众号开发——快速入门的更多相关文章

  1. 微信公众号开发系统入门教程(公众号注册、开发环境搭建、access_token管理、Demo实现、natapp外网穿透)

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/a1786223749/article/ ...

  2. C#微信公众号开发入门教程

    首先打开开发文档: 微信公众号开发者文档:http://mp.weixin.qq.com/wiki/home/index.html 一.创建测试账号 可以先申请一个开发者测试账号

  3. 带领技术小白入门——基于java的微信公众号开发(包括服务器配置、java web项目搭建、tomcat手动发布web项目、微信开发所需的url和token验证)

    微信公众号对于每个人来说都不陌生,但是许多人都不清楚是怎么开发的.身为技术小白的我,在闲暇之余研究了一下基于java的微信公众号开发.下面就是我的实现步骤,写的略显粗糙,希望大家多多提议! 一.申请服 ...

  4. 微信公众号开发C#系列-12、微信前端开发利器:WeUI

    1.前言 通过前面系列文章的学习与讲解,相信大家已经对微信的开发有了一个全新的认识.后端基本能够基于盛派的第三方sdk搞定大部分事宜,剩下的就是前端了.关于手机端的浏览器的兼容性问题相信一直是开发者们 ...

  5. 线程安全使用(四) [.NET] 简单接入微信公众号开发:实现自动回复 [C#]C#中字符串的操作 自行实现比dotcore/dotnet更方便更高性能的对象二进制序列化 自已动手做高性能消息队列 自行实现高性能MVC WebAPI 面试题随笔 字符串反转

    线程安全使用(四)   这是时隔多年第四篇,主要是因为身在东软受内网限制,好多文章就只好发到东软内部网站,懒的发到外面,现在一点点把在东软写的文章给转移出来. 这里主要讲解下CancellationT ...

  6. .NET开发者如何愉快的进行微信公众号开发

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:这篇文章只是一个如何提高开发效率的简单指导和记录,不会涉及具体的微信公众号开发内容. ...

  7. 微信公众号开发C#系列-11、生成带参数二维码应用场景

    1.概述 我们在微信公众号开发C#系列-7.消息管理-接收事件推送章节有对扫描带参数二维码事件的处理做了讲解.本篇主要讲解通过微信公众号开发平台提供的接口生成带参数的二维码及应用场景. 微信公众号平台 ...

  8. 微信公众号开发C#系列-9、多公众号集中管理

    1.概述 通过前面8篇关于微信开发相关文章的学习,我们已经对微信常用开发有了一个比较深入的了解.前面的文章都是基于某一特定公众号的,在现实业务中同一单位个体运营着不至一个公众号,此时就需要对多个公众号 ...

  9. 微信公众号开发C#系列-7、消息管理-接收事件推送

    1.概述 在微信用户和公众号产生交互的过程中,用户的某些操作会使得微信服务器通过事件推送的形式通知到开发者在开发者中心处设置的服务器地址,从而开发者可以获取到该信息.其中,某些事件推送在发生后,是允许 ...

随机推荐

  1. berkeley db replica机制 - 主从同步

    repmgr/repmgr_net.c, __repmgr_send(): 做send_broadcast, 然后根据policy 对DB_REP_PERMANENT的处理 __repmgr_send ...

  2. linux内核调优详解

    cat > /etc/sysctl.conf << EOF net.ipv4.ip_forward = net.ipv4.conf.all.rp_filter = net.ipv4. ...

  3. andriod终端操作命令

    1.卸载大厅安装包,如果卸载不掉的话,添加-r pm uninstall -r com.scigames.egm.lobby 2.查找包含"scigames"的安装包 3.卸载一个 ...

  4. 揭秘Sql2014新特性-tempdb性能提升

    一直以来,在高负载,复杂的生产环境中,tempdb的压力是成为整个实例瓶颈的重要因素之一.微软的工程师们也在各个版本中不断优化它的使用.到了Sql Server2014又有了新的特性使其性能得temp ...

  5. Orchard Platform v1.8 发布

    发布说明: 1. 添加Json格式数据文件支持.2. 彻底删除了Settings, Modules, Themes模块.3. 删除了默认的ContentType,Site和User.4. 支持空库(无 ...

  6. JS备忘录

    /** *删除数组指定下标或指定对象 */ Array.prototype.remove = function (obj) { for (var i = 0; i < this.length; ...

  7. Nim教程【五】

    妈蛋,花了两天时间才搞定博客园的API, 比预期的时间整整多了1天, 不管怎么说,总算把博客园的客户端搞定了 这篇文章就是用博客园的客户端发布的, 先贴张图,给大家看看, 后面我会和博客园的领导商量一 ...

  8. [芯片] 3、接口技术·实验三·可编程并行接口8255A

    目录 一.实验目的和要求 二.实验原理与背景 2-1.8255A简介 2-2.8255A编程 三.实验具体的内容 3-1.8255方式0实验1 3-2.8255方式0实验2 3-3.8255方式1输出 ...

  9. JS动态修改页面EasyUI datebox不生效、EasyUI动态添加Class、EasyUI动态渲染解析解决方案

    这是个小菜在实际工作中遇到的问题,相信很多EasyUI新手很可能也遇到这样的问题,因此小菜觉得有必要拿出来分享一下. 这个问题要从EasyUI的datebox组件说起,小菜用这个组件的时候,发现用$( ...

  10. 升级ruby版本那"不堪回首的经历"

    前段时间在玩Chef-一个IT基础设施自动化工具.由于Chef是由Ruby写的一个gem,那么就需要安装Ruby.当然Ruby我早就安装了,并且使用rvm来管理Ruby及Gem.本来一切看似正常,但是 ...