.NET开发者如何愉快的进行微信公众号开发
(此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注。)
题记:这篇文章只是一个如何提高开发效率的简单指导和记录,不会涉及具体的微信公众号开发内容。
就我理解,微信作为半个移动互联网入口,且已经在代替大量APP的趋势下,进行微信公众号开发是一个开发者必须面对的命运。那么.NET开发者如何高效的进行微信公众号开发呢?从我有限的经验来看,如下两个方面是特别需要解决的。
1,SDK的选择和使用
由于微信公众平台的访问接口庞大繁杂且基于HTTP API的,如果从底层开始写每一行代码就未免耗时费力。幸好,基于.NET的SDK还是有很多,比如之前我的文章《使用ASP.NET MVC、Rabbit WeixinSDK和Azure快速开发部署微信后台》中介绍的Rabbit WeixinSDK。最近在研究的Senparc.Weixin SDK更是一个强大和全面的开源SDK。已全面支持微信公众号、微信支付、企业号、开放平台、JSSDK、摇一摇周边等模块。这个SDK做了很多底层封装,比如AccessToken的自动管理、用户上下文的支持等等,让开发者更加专注于业务逻辑的实现。更多信息可以参考官网:http://weixin.senparc.com/。
要使用也很简单,直接“Install-Package Senparc.Weixin.MP”,如果使用MVC开发的话,可以再安装“Senparc.Weixin.MP.MVC”。不过暂不支持ASP.NET Core。
2,程序的调试(包括本地和远程)
众所周知,微信公众号的运行机制决定了微信服务器必须访问一个80端口的公网地址,这给程序调试带来了一些障碍。不过使用相应工具并通过如下步骤还是很容易进行本地和远程调试的:
2.1,开通“公众平台测试帐号”
开通公众号中的“开发者工具”的“公众平台测试帐号”。在这个工具里面实际上模拟了真实公众号的后台配置,具体配置的内容需要后续步骤来提供。
2.2,设置本地调试
所谓本地调试就是指让“公众平台测试帐号”可以访问开发机器上跑的IISExpress,从而实现Visual Studio对代码的Debug。实现本地调试的最简单方法,当然是配置路由器DMZ(或者端口映射)+动态域名。如果使用的是光宽带,那么自己的路由器一般是在电信运营商光猫(其集成了路由器)之后,端口映射就无效。这个时候只有借助于花生壳之类的工具来把本机端口映射为外网80端口。如果只是开发调试的话,个人免费版足够了。
如下图,就是把本地一个MVC项目的运行端口映射到花生壳免费子域名下的80端口。

有了这个外网地址之后,就可以填写到“公众平台测试帐号”中的“接口配置信息”的URL中。填写的时候,如果遇到“提交失败”,那么可以多试几次,也可以把花生壳重启一下看看。如下图所示:

其中wechat是我的测试项目中用于和微信服务器交互的MVC Controller的名字。经过这样的配置,就可以愉快的在本地调试微信公众号应用了。
2.3,配置远程调试
所谓远程调试,就是当你把公众号应用发布到公网服务器上的时候,通过配置Visual Studio的远程调试功能,从而实现对生产服务器的Debug。
要配置远程调试,我能想到的最便捷的方式就是把应用发布到Azure的App Service中,然后启用远程调试功能。如下图所示:

要把VS附加到远程应用上,最简单的方式就是通过VS的Server Explorer中的Azure浏览器找到你的应用的节点,点击右键来选择“Attach Debugger”,如下图所示:

当然这个时候,记得要把“公众平台测试帐号”中的“接口配置信息”的URL改为Azure中的地址。如果公众号应用是发布到虚拟机中,那么也可以通过安装远程调试插件来实现VS远程调试,相关资料可以Bing一下。
另外,如果在团队开发的情况下,建议每个人都独立申请“公众平台测试帐号”、花生壳端口映射和Azure帐号,各自使用自己的环境来调试,互不影响。
.NET开发者如何愉快的进行微信公众号开发的更多相关文章
- 微信公众号开发C#系列-2、微信公众平台接入指南
概述 微信公众平台消息接口的工作原理大概可以这样理解:从用户端到公众号端一个流程是这样的,用户发送消息到微信服务器,微信服务器将接收到的消息post到用户接入时填写的url中,在url处理程序中,首先 ...
- 微信公众号开发(一)--验证服务器地址的Java实现
现在主流上都用php写微信公众号后台,其实作为后端语言之一的java也可以实现. 这篇文章将对验证服务器地址这一步做出实现. 参考资料:1.慕课网-<初识java微信公众号开发>,2.微信 ...
- C#微信公众号开发系列教程三(消息体签名及加解密)
http://www.cnblogs.com/zskbll/p/4139039.html C#微信公众号开发系列教程一(调试环境部署) C#微信公众号开发系列教程一(调试环境部署续:vs远程调试) C ...
- C#微信公众号开发系列教程二(新手接入指南)
http://www.cnblogs.com/zskbll/p/4093954.html 此系列前面已经更新了两篇博文了,都是微信开发的前期准备工作,现在切入正题,本篇讲解新手接入的步骤与方法,大神可 ...
- 微信公众号开发系列教程一(调试环境部署续:vs远程调试)
http://www.cnblogs.com/zskbll/p/4080328.html 目录 C#微信公众号开发系列教程一(调试环境部署) C#微信公众号开发系列教程一(调试环境部署续:vs远程调试 ...
- NET微信公众号开发-5.0微信支付(待测试)
开发前准备. 1.0微信支付官方开发者文档 2.0官方demo下载 我们用c#所以选择.net版本 不过这个官方的demo根本跑步起来 3.0官方demo运行起来解决方案 4.0微信支付官方.net版 ...
- 利用OpenShift托管Node.js Web服务进行微信公众号开发
最近写了一个微信的翻译机器人.用户只要关注该公众号,发送英文的消息,就能收到中文翻译的回复.有兴趣的读者可以扫描下面的二维码关注该公众号,尝试发送英文单词试试看.(有时候第一次发送单词会收到“该公众号 ...
- .net微信公众号开发——消息与事件
作者:王先荣 本文介绍如何处理微信公众号开发中的消息与事件,包括:(1)消息(事件)概况:(2)验证消息的真实性:(3)解析消息:(4)被动回复消息:(5)发送其他消息. 开源项目地址:h ...
- C#微信公众号开发系列教程六(被动回复与上传下载多媒体文件)
微信公众号开发系列教程一(调试环境部署) 微信公众号开发系列教程一(调试环境部署续:vs远程调试) C#微信公众号开发系列教程二(新手接入指南) C#微信公众号开发系列教程三(消息体签名及加解密) C ...
随机推荐
- Leetcode 40. Combination Sum II
Given a collection of candidate numbers (C) and a target number (T), find all unique combinations in ...
- sql 知识点系统汇总
提供性能: .服务器往往具有强大的计算能力和速度..避免把大量的数据下载到客户端,减少网络上的传输量. 第一章 T-SQL 语句 1.1数据类型 文本型 -- CHAR 定长型 <=8000字节 ...
- Python Day3
一.set集合 集合是一个无序的,不重复的数据组合,它的主要作用如下: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 # 创建数值集合 list_1 = ...
- iframe子页面点击按钮,执行父页面的点击事件
iframe 子页面点击.parent 父页面 的id(auth-link-btn)的事件 <a href="javascript:void(0);" onclick=&q ...
- Tomcat SSL的安装及配置中遇到问题
配置tomcat服务器利用SSL进行加密. 一.生成密钥库 具体生成方式就不讲了,tomcat支持的keystore的格式有JKS,PKCS11和PKCS12 JKS是jdk /bin目录下keyto ...
- .htaccess 基础教程(四)Apache RewriteCond 规则参数
Apache模块 mod_rewrite 提供了一个基于正则表达式分析器的重写引擎来实时重写URL请求.它支持每个完整规则可以拥有不限数量的子规则以及附加条件规则的灵活而且强大的URL操作机制.此UR ...
- Daily Scrum Meeting ——TenthDay
一.Daily Scrum Meeting照片 二.Burndown Chart 新增了几个issues 三.项目进展 1.完成了登录界面与管理员和发布者界面的整合. 2.活动发布者界面的完成 四.问 ...
- 06OC之内存管理
在高级语言中,例如C#是通过垃圾回收机制(GC)来解决这个问题,但是在OC并没有类似的垃圾回收机制,因此必须由程序员手动去维护.今天就讲讲OC中的内存管理: 一.内存管理原理 在Xcode4.2之后的 ...
- ReflectionToStringBuilder类
ReflectionToStringBuilder类是用来实现类中的toString()方法的类,它采用Java反射机制(Reflection),通过reflection包中的AccessibleOb ...
- 开大你的音响,感受HTML5 Audio API带来的视听盛宴
话说HTML5的炫酷真的是让我爱不释手,即使在这个提到IE就伤心不完的年代.但话又说回来,追求卓越Web创造更美世界这样高的追求什么时候又与IE沾过边儿呢?所以当你在看本文并且我们开始讨论HTML5等 ...