微信开发系列-----03:实现各种消息的响应

简介: 微信开发系列-----03:实现各种消息的响应

续之前我们没有完成的部分,现在可以实现简单的文本交互,这篇将实现各种消息,事件的响应。


项目GitHub地址:  https://github.com/Andyahui/xgyxsh_WeiXin


SDK的GitHub地址https://github.com/JeffreySu/WeiXinMPSDK/


SDK官方介绍博客http://www.cnblogs.com/szw/archive/2013/05/14/weixin-course-index.html


一:实现各类消息的简单回复


    基于现在的底层框架,我们不难看出其余的响应机制不是很难,只是我们不是很熟悉这个SDK而已;现在已经实现了文本回复,我们在重写OnTextRequest方法的时候发现有很多的重新方法,如下。

679140-20160626224331516-1030050110.png


这个就是我们需要实现各种消息机制和事件机制的方法。可以通过实现对应的方法来响应微信服务器发送过来的各种POST请求,如果网站有很多的需求,那么处理的业务逻辑就是在这些方法中进行。



  • 1.1:处理语音请求;


public override IResponseMessageBase OnVoiceRequest(RequestMessageVoice requestMessage)
{
    var responseVoice = base.CreateResponseMessage<ResponseMessageVoice>();
    responseVoice.Voice=new Voice()
    {                
        MediaId = requestMessage.MediaId
    };           
    return responseVoice;
}


   我们客户端发送的语音请求先到OnVoiceRequest方法中,要是没有任何的回复就到默认回复方法中回复用户消息。在上面方法测试中我们创建了语音的回复,默认回复它自己的语音,MediaId是通过素材管理接口上传的多媒体文件得到的ID,其实就是微信服务器保存用户发送语音的ID;


  • 1.2:处理图片请求;


public override IResponseMessageBase OnImageRequest(RequestMessageImage requestMessage)
{
    var responseImage = base.CreateResponseMessage<ResponseMessageText>();
    responseImage.Content = "来自图片,ahui";
    return responseImage;
}


 用户发送的图片请求,之后我们回复文本。要是需要复杂的逻辑我们可以自己在这里添加。其中的base.CreateResponseMessage()就是创建了一个回复的文本类型;



  • 1.3:处理地理位置请求;


public override IResponseMessageBase OnLocationRequest(RequestMessageLocation requestMessage)
{
    //返回的是图文消息,是关于地址的图文消息。
    var responseLocation = base.CreateResponseMessage<ResponseMessageNews>();
    var markersList = new List<BaiduMarkers>();
    markersList.Add(new BaiduMarkers()
    {
        Size=BaiduMarkerSize.m,
        Color ="red",
        Label="A",
        Latitude =requestMessage.Location_X,
        Longitude=requestMessage.Location_Y,
    });
    var mapUrl = BaiduMapHelper.GetBaiduStaticMap(requestMessage.Location_Y,requestMessage.Location_X,1,13,markersList);
    responseLocation.Articles.Add(new Article()
    {
        Description = string.Format("您刚才发送了地理位置信息。Location_X:{0},Location_Y:{1},Scale:{2},标签:{3}",requestMessage.Location_X,requestMessage.Location_Y,requestMessage.Scale,requestMessage.Label),
        PicUrl = "http://pic.cnblogs.com/avatar/679140/20141128195544.png",
        Title="张辉的地图",
        Url = mapUrl
    });
    return responseLocation;
}


处理地理位置请求,用户发送自己的地理位置,我们可以给用户发送任何我们想发送的信息,上面是调用百度地图的接口,将它自己的信息又重新的发送。



  • 1.4:处理链接请求;


public override IResponseMessageBase OnLinkRequest(RequestMessageLink requestMessage)
{
    var responseLink = base.CreateResponseMessage<ResponseMessageNews>();
    responseLink.Articles.Add(new Article()
    {
        Title="处理链接来的请求。",
        Description =requestMessage.Description,
        PicUrl = "http://pic.cnblogs.com/avatar/679140/20141128195544.png",
        Url=requestMessage.Url
    });
    return responseLink;
}

关于链接也是回复图文消息,之前的很多都是回复图文消息,但是我们需要注意里面的参数,这样才可以符合微信的回复内容。


二:POST事件的回复


    微信用户和公众号的交互过程中,用户的一些操作会使微信服务器以事件的形式发送请求到开发者设置的网站服务器上,某些事件可以让我们回复用户信息;下面就是来处理这些的。


微信开发者文档的事件推送:


           http://mp.weixin.qq.com/wiki/7/9f89d962eba4c5924ed95b513ba69d9b.html


带有Event_标识的代表就是事件的方法,我们需要重写这些方法来实现我们的回复。这里面有很多可以看官网的介绍。



2.1:订阅事件


/// <summary>
/// 订阅事件
/// </summary>
/// <param name="requestMessage"></param>
/// <returns></returns>
public override IResponseMessageBase OnEvent_SubscribeRequest(RequestMessageEvent_Subscribe requestMessage)
{
    var responseSubscribe = base.CreateResponseMessage<ResponseMessageText>();
    responseSubscribe.Content = "欢迎订阅,张辉欢迎您。";
    return responseSubscribe;
}



回复的是文本内容,这有利于测试,我们可以添加任何的逻辑,也可以回复任何的图文,语音,文本等类型。这就要看项目的需求了。


  • 2.2:点击菜单拉取消息时的事件推送


/// <summary>
/// 点击事件
/// </summary>
/// <param name="requestMessage"></param>
/// <returns></returns>
public override IResponseMessageBase OnEvent_ClickRequest(RequestMessageEvent_Click requestMessage)
{
    var respondeEvert = base.CreateResponseMessage<ResponseMessageText>();
    respondeEvert.Content = "点击事件,";
    return respondeEvert;
}


这里你可能不知道这个点击事件是什么,这个是在菜单栏那边设置的,我们之后就会实现菜单栏的功能。


  • 2.3:点击菜单跳转链接时的事件推送


public override IResponseMessageBase OnEvent_ViewRequest(RequestMessageEvent_View requestMessage)
{
    var responseView = base.CreateResponseMessage<ResponseMessageText>();
    responseView.Content = "点击带有view的菜单栏";
    return responseView;
}


三:实现微信公众号自定义菜单


    每一个微信的页面下基本上都有菜单栏,人家的那个是通过常规的设置可以实现的,现在我们的只是测试号,在测试号页面找了好久都没有发现,最后经过查询在开发者调试中可以设置。还有一种是利用SDK提供的页面来实现。


  •  3.1:利用开发者调试工具实现自定义菜单



679140-20160626224332641-1693270713.png


开发者调试工具网址:https://mp.weixin.qq.com/debug/cgi-bin/apiinfo?t=index&type=%E6%B6%88%E6%81%AF%E6%8E%A5%E5%8F%A3%E8%B0%83%E8%AF%95&form=%E4%BA%8B%E4%BB%B6%E6%B6%88%E6%81%AF


    我们发现这个还需要access_token来请求,但是我们从之前的开发中都没有发现有这个,那么这个是什么呢,仔细的看官方的介绍吧;


获取access_token,我们可以通过开发者调试工具,利用AppId和secret来获取;


679140-20160626224334297-1139555375.png


在第一幅图中我们还需要body,调用接口的json数据包;可以参考微信开发文档里面的进行设置。注意里面就会看到click和view这两个事件类型


{
        "button": [
            {
                "name": "IT资讯", 
                "sub_button": [
                    {
                        "type": "view", 
                        "name": "博客园", 
                        "url": "http://m.cnblogs.com/", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "view", 
                        "name": "IT新闻", 
                        "url": "http://news.cnblogs.com/m", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "关于开发者", 
                        "key": "http://m.cnblogs.com/?u=netxiaohui", 
                        "sub_button": [ ]
                    }
                ]
            }, 
            {
                "name": "校园生活", 
                "sub_button": [
                    {
                        "type": "view", 
                        "name": "搜索", 
                        "url": "http://www.baidu.com/", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "view", 
                        "name": "视频", 
                        "url": "http://v.qq.com/", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "关注我们", 
                        "key": "V1001_GOOD", 
                        "sub_button": [ ]
                    }
                ]
            }, 
            {
                "name": "学生", 
                "sub_button": [
                    {
                        "type": "view", 
                        "name": "搜索", 
                        "url": "http://www.soso.com/", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "view", 
                        "name": "视频", 
                        "url": "http://v.qq.com/", 
                        "sub_button": [ ]
                    }, 
                    {
                        "type": "click", 
                        "name": "关注我们", 
                        "key": "V1001_GOOD", 
                        "sub_button": [ ]
                    }
                ]
            }
        ]
    }


  关于里面的事件类型,我们可以自己随意的设置,都会响应我们前面设置的菜单事件,我们可以进行一系列的逻辑代码的处理。


3.2:SDK的自定义菜单


     通过下面的网址可以 进行设置,里面还是需要前面的两个参数AppId和secret或者Token来设置微信的自定义菜单。


设置自定义菜单网址:http://sdk.weixin.senparc.com/Menu



679140-20160626224336531-1398981498.png679140-20160626224338047-1401955425.png


四:最终的结果展示



   实现上面的代码就可以实现相应的功能。这个SDK简单的使用我们现在已经大体的会了,在之后的博文中会慢慢的解析这个SDK里面的一些东西,会从Request,Response等基础开始。



679140-20160626224339860-1002559616.png679140-20160626224342281-1863821798.png

----------------------------------请继续关注!-------------------------------------



目录
相关文章
|
5月前
|
Web App开发 缓存 小程序
【Azure API 管理】从微信小程序访问APIM出现200空响应的问题中发现CORS的属性[terminate-unmatched-request]功能
【Azure API 管理】从微信小程序访问APIM出现200空响应的问题中发现CORS的属性[terminate-unmatched-request]功能
|
小程序
【微信小程序错误】登录失败 Error: 响应错误Error: ERR_GET_SESSION_KEY {"code":5100,message(-1)服务内部错误,请稍后重试或联系客服人员解决
登录失败 Error: 响应错误Error: ERR_GET_SESSION_KEY {"code":5100,message(-1)服务内部错误,请稍后重试或联系客服人员解决
483 0
|
PHP
PHP-微信公众平台开发-接收用户输入消息类型并响应
原文:PHP-微信公众平台开发-接收用户输入消息类型并响应 MsgType); //用户发送的消息类型判断 switch ($RX_TYPE) { case "text": ...
891 0
|
开发者
微信公众平台接口报警功能 响应出问题随时发现
  这段时间网络攻击还是很频繁,ddos会导致你的服务器宕机,连接微信公众平台的服务器和接口响应出现问题那就不足为奇了,如何第一时间发现问题呢?微信团队为你想到了,发布公众平台更新,为开发者提供接口报警功能。
1217 0
微信公众平台消息接口开发(29)校验签名与消息响应合并
微信公众平台开发 微信公众平台开发者 微信公众平台开发模式 签名校验 消息响应作者:方倍工作室原文:http://www.cnblogs.com/txw1958/archive/2013/05/08/weixin-if29-valid-responseMsg.
916 0
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
776 7
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
785 1
|
3月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
183 7