微信快速开发框架(四)-- 体验微信公众平台快速开发框架

简介: 今天上午想着用那个框架来快速建立一个测试,用着用着,发觉了些bug,赶紧修复了下,目前已经更新到github上。 接下来,我们的快速开发,首先您要建立一个公众账号的测试账号,建立方法参见《建立微信公众平台测试账号》,我在项目中,加入了WebDemo项目,您可以参考以下。

今天上午想着用那个框架来快速建立一个测试,用着用着,发觉了些bug,赶紧修复了下,目前已经更新到github上。

接下来,我们的快速开发,首先您要建立一个公众账号的测试账号,建立方法参见《建立微信公众平台测试账号》,我在项目中,加入了WebDemo项目,您可以参考以下。

上一篇介绍中,我说过先建立规则,但细想以下,貌似先要建立消息处理类,然后才能在规则中使用。

实践一下,这里我用了2个消息处理,一个是DefaultMessageHandler和CnBlogsMessageHandler,一个是默认的消息,在无法处理时返回,CnblogsMessageHandler是一个文本消息处理,您只要回复“博客园”就能看到相应的反馈消息。

先建立2个MessageHandler都继承IMessageHandler:

public class DefaultMessageHandler : IMessageHandler
    {
        private static string s_defaultMsg = "对不起,亲,我还无法了解您的需求,我会不断改进的!";

        public ResponseMessage HandlerRequestMessage(XElement xml)
        {
            var fromUserName = xml.Element("ToUserName").Value;
            var toUserName = xml.Element("FromUserName").Value;
            return new ResponseTextMessage
            {
                FromUserName = fromUserName,
                ToUserName = toUserName,
                CreateTime = DateTime.Now.Ticks,
                Content = s_defaultMsg
            };
        }
    }
public class CnblogsTextMessageHandler : IMessageHandler
    {
        private static string s_cnblogsMsg = "HI,博客园的园友,欢迎来到JamesYing的微信世界,请关注我,http://inday.cnblogs.com";
        public ResponseMessage HandlerRequestMessage(XElement xml)
        {
            var request = new RequestTextMessage(xml);
            return new ResponseTextMessage(request)
            {
                CreateTime = DateTime.Now.Ticks,
                Content = s_cnblogsMsg
            };
        }
    }

 

后面建立一些规则:

这里我建立了几套规则,先建立了主体规则:

public class WebMessageRole : IMessageRole
    {
        public IMessageHandler MessageRole(XElement xml)
        {
            try
            {
                var msgType = (MsgType)Enum.Parse(typeof(MsgType), xml.Element("MsgType").Value, true);

                return new MsgTypeMessageRole(msgType).MessageRole(xml);
            }
            catch
            {
                return new DefaultMessageHandler();
            }
        }
    }

MsgTypeMessageRole是一个根据类型处理的规则,与之前Demo不同,我把规则都细分了,这样耦合度减小,可以根据不同需求,在不同规则中修改。

public class MsgTypeMessageRole : IMessageRole
    {
        private MsgType MsgType { get; set; }

        public MsgTypeMessageRole(MsgType msgType)
        {
            this.MsgType = msgType;
        }

        public IMessageHandler MessageRole(XElement xml)
        {
            switch (MsgType)
            {
                case MsgType.Text:
                    return new TextMessageRole().MessageRole(xml);
                default:
                    return new DefaultMessageHandler();
            }
        }
    }

这里在判断为Text的时候,返回了另外一个规则,文本消息处理规则TextMessageRole,其余情况下则直接返回一个默认的消息处理DefaultMessageHandler

public class TextMessageRole : IMessageRole
    {
        public IMessageHandler MessageRole(XElement xml)
        {
            var request = new RequestTextMessage(xml);
            if (request.Content.IndexOf("博客园") > -1)
            {
                return new CnblogsTextMessageHandler();
            }

            return new DefaultMessageHandler();
        }
    }

TextMessageRole 是个很简单的规则类,我只是判断在文本内容中是否含有“博客园”三个字,有的话,我直接返回CnblogsTextMessageHandler

基本的处理都好了,接下来是在微信接口中,进行部署,在web项目中wx.aspx为接口地址。

我的公开测试地址:http://wx.jamesying.com/wx.aspx

在wx.aspx.cs中,进行一些必要的配置:

public partial class WX : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                //微信服务器一直把用户发过来的消息,post过来
                if (Request.HttpMethod == "POST")
                {
                    var reader = XmlReader.Create(Request.InputStream);
                    
                    var doc = XDocument.Load(reader);
                    MyLog.Log(doc.ToString());
                    var xml = doc.Element("xml");
                    //把inputstream转换成xelement后,直接交给WebMessageRole来处理吧
                    var responseMessage =  new WebMessageRole()
                        .MessageRole(xml)
                        .HandlerRequestMessage(xml);

                    if (responseMessage != null)
                    {
                        Response.Write(responseMessage.Serializable());
#if DEBUG
                        MyLog.Log(responseMessage.Serializable());
#endif
                    }
                }
                else if (Request.HttpMethod == "GET") //微信服务器在首次验证时,需要进行一些验证,但。。。。
                {
                    //我仅需返回给他echostr中的值,就为验证成功,可能微信觉得这些安全策略是为了保障我的服务器,要不要随你吧
                    Response.Write(Request["echostr"].ToString());
                }
            }
            catch (Exception ex)
            {
                MyLog.Log("error:" + ex.ToString());
            }
        }
    }

至此,一个简单的微信公众平台接口已经配置完成,只要部署到自己的web服务器即可。在上一篇中,有人提到了之前有过接口+工厂的模式,说实在,真没看过,可能最近比较懒,没一直刷博客园吧。不过看了@戢俊建 的一篇关于微信平台的文章,觉得写得蛮好的,大家也可以看看。

做这个框架的目的,也是为了方便大家来进行开发,昨天有用户说提供一些模板比较好(其实就是MessageHandler),我觉得这个方案不错,过几天申请个公众账号,写几个常用的处理类,方便大家。当然也可以大家自己写,Email给我也行。

下面看下效果,您如果也要看效果,请关注我的测试账号(必须用扫一扫功能扫二维码才能添加):QQ截图20131211120953

我用了web weixin:

image

亲,可以关注我的微信:jamesying1

相关文章
|
9天前
|
小程序 安全 搜索推荐
【微信小程序开发实战项目】——个人中心页面的制作
本文介绍了如何设计和实现一个网上花店的微信小程序,包括个人中心、我的订单和我的地址等功能模块。个人中心让用户能够查看订单历史、管理地址和与客服互动。代码示例展示了`own.wxml`、`own.wxss`和`own.js`文件,用于构建个人中心界面,包括用户信息、订单链接、收藏、地址、客服和版本信息。我的订单部分展示了订单详情,包括商品图片、名称、销量、价格和订单状态,用户可以查看和管理订单。我的地址功能允许用户输入和编辑收货信息,包括联系人、性别、电话、城市和详细地址。每个功能模块都附有相应的WXML和WXSS代码,以及简洁的样式设计。
40 0
【微信小程序开发实战项目】——个人中心页面的制作
|
9天前
|
小程序 安全 搜索推荐
【微信小程序开发实战项目】——如何制作一个属于自己的花店微信小程序(3)
这是一篇关于微信小程序开发的文章摘要,作者介绍了如何创建一个网上花店小程序,旨在提供便捷的购花体验。小程序包含鲜花分类功能,允许用户按品种、颜色和用途筛选,确保快速找到合适的鲜花。它还提供了配送服务,保证鲜花的新鲜度。文章展示了`cash.wxml`、`cash.wxss`和`cash.js`的部分代码,用于实现分类和商品展示,以及`qin.wxml`、`qin.wxss`和`qin.js`,涉及商品详情和购买付款流程。代码示例展示了商品列表渲染和交互逻辑,包括页面跳转、数据传递和点击事件处理。文章最后提到了购买付款界面,强调了安全和便捷的支付体验。
38 0
【微信小程序开发实战项目】——如何制作一个属于自己的花店微信小程序(3)
|
22天前
|
小程序 开发者
uniapp实战 —— 开发微信小程序的调试技巧
uniapp实战 —— 开发微信小程序的调试技巧
21 1
|
22天前
|
小程序
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
30 0
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
|
22天前
|
小程序 定位技术 API
uniapp 开发微信小程序 --【地图】打开地图选择位置,打开地图显示位置(可开启导航)
uniapp 开发微信小程序 --【地图】打开地图选择位置,打开地图显示位置(可开启导航)
104 0
|
22天前
|
小程序 前端开发
【微信小程序-原生开发】添加自定义图标(以使用阿里图标库为例)
【微信小程序-原生开发】添加自定义图标(以使用阿里图标库为例)
26 0
|
22天前
|
小程序
【微信小程序-原生开发】客服
【微信小程序-原生开发】客服
86 0
|
22天前
|
小程序
【微信小程序-原生开发】wxml 支持 includes (wxml中执行函数的方法)
【微信小程序-原生开发】wxml 支持 includes (wxml中执行函数的方法)
39 0
|
22天前
|
小程序 JavaScript
【微信小程序-原生开发】watch 的实现
【微信小程序-原生开发】watch 的实现
28 0
|
22天前
|
小程序 JavaScript
【微信小程序-原生开发】实用教程11 - 用户登录鉴权(含云函数的创建、删除、使用,通过云函数获取用户的openid)
【微信小程序-原生开发】实用教程11 - 用户登录鉴权(含云函数的创建、删除、使用,通过云函数获取用户的openid)
23 0