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

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

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

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

{

var responseVoice = base.CreateResponseMessage();

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();

responseImage.Content = "来自图片,ahui";

return responseImage;

}

用户发送的图片请求,之后我们回复文本。要是需要复杂的逻辑我们可以自己在这里添加。其中的base.CreateResponseMessage()就是创建了一个回复的文本类型;1.3:处理地理位置请求;public override IResponseMessageBase OnLocationRequest(RequestMessageLocation requestMessage)

{

//返回的是图文消息,是关于地址的图文消息。

var responseLocation = base.CreateResponseMessage();

var markersList = new List();

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();

responseLink.Articles.Add(new Article()

{

Title="处理链接来的请求。",

Description =requestMessage.Description,

PicUrl = "http://pic.cnblogs.com/avatar/679140/20141128195544.png",

Url=requestMessage.Url

});

return responseLink;

}

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

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

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

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

/// 订阅事件

///

///

///

public override IResponseMessageBase OnEvent_SubscribeRequest(RequestMessageEvent_Subscribe requestMessage)

{

var responseSubscribe = base.CreateResponseMessage();

responseSubscribe.Content = "欢迎订阅,张辉欢迎您。";

return responseSubscribe;

}

回复的是文本内容,这有利于测试,我们可以添加任何的逻辑,也可以回复任何的图文,语音,文本等类型。这就要看项目的需求了。2.2:点击菜单拉取消息时的事件推送///

/// 点击事件

///

///

///

public override IResponseMessageBase OnEvent_ClickRequest(RequestMessageEvent_Click requestMessage)

{

var respondeEvert = base.CreateResponseMessage();

respondeEvert.Content = "点击事件,";

return respondeEvert;

}

这里你可能不知道这个点击事件是什么,这个是在菜单栏那边设置的,我们之后就会实现菜单栏的功能。2.3:点击菜单跳转链接时的事件推送public override IResponseMessageBase OnEvent_ViewRequest(RequestMessageEvent_View requestMessage)

{

var responseView = base.CreateResponseMessage();

responseView.Content = "点击带有view的菜单栏";

return responseView;

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

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

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

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

在第一幅图中我们还需要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来设置微信的自定义菜单。

四:最终的结果展示

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

微信响应菜单点击事件php,微信开发实现各种消息的响应相关推荐

  1. PC端微信浏览器js点击事件失效

    **电脑端微信浏览器js点击事件失效**前段时间发现开发的一个微信公众号上一个按钮的点击事件在手机上是正常的,电脑端手机微信里却不起作用.在网上找了好久都没有找到解决办法.后来查看其它的页面的同样的点 ...

  2. [微信小程序]微信小程序点击事件返回值的target分析

    微信小程序点击事件返回值的target分析 测试过程 在微信小程序中创建以下图片 然后在调试中点击下面第5个. console返回两个e 第一个e是第5块小块的e 第二个e是下面全部9小块组成的大块的 ...

  3. C#开发微信门户及应用(9)-微信门户菜单管理及提交到微信服务器

    原文:C#开发微信门户及应用(9)-微信门户菜单管理及提交到微信服务器 微信公众号(包括服务号和订阅号)都可以对菜单进行自定义设置,我们为了方便管理,一般先把菜单数据在本地管理维护,需要更新的时候,把 ...

  4. hitTest和pointInside如何响应用户点击事件

    hitTest和pointInside如何响应用户点击事件 处理机制 iOS事件处理,首先应该是找到能处理点击事件的视图,然后在找到的这个视图里处理这个点击事件. 处理原理如下: • 当用户点击屏幕时 ...

  5. QT实现控件不响应鼠标点击事件

    QT中很多控件都有鼠标点击的事件响应,比如QPushButton,QRadioButton.有时候我们想要实现的是:当鼠标点击控件时,不会产生响应事件.其中的一种方法是使用Qt::WA_Transpa ...

  6. 微信小程序服务器未响应,微信小程序点击事件失效

    想在主页上添加一个搜索功能 但是加上之后发现原有的页面点击事件没有反应了 个人怀疑是input和bindtap互相影响? 有人碰到类似的情况吗 是怎么解决的 {{item}} this is a te ...

  7. 从点击事件看微信小程序的数据传递

    最近用微信小程序做了一个电影类APP,业务逻辑不难,但在做最后一个页面时遇到了一个诡异的问题,这个问题让我对小程序框架里的事件和数据绑定有了更深的认识. 问题是这样的: 该小程序有4个页面,分别是&q ...

  8. cocos微信小游戏开发-http请求-使用微信云函数-toast-loading-动态加载图片-添加触摸事件-微信分享-label点击事件-背景音乐音效-程序活动状态判断-性能优化

    cocos开发微信小游戏相关-<益智推箱> 扫码查看功能,有需要可直接提问 Cocos Creator 3.4 用户手册 cocos creator基本操作 微信开发文档|云函数 1. h ...

  9. php点击事件唤起微信聊天,vbot微信机器人微信聊天消息详解(15):点击消息

    <vbot微信机器人微信聊天消息详解(15):点击消息>要点: 本文介绍了vbot微信机器人微信聊天消息详解(15):点击消息,希望对您有用.如果有疑问,可以联系我们. 点击是机器人在账号 ...

最新文章

  1. Mysql统计分组区间的人数和
  2. jq取第一个子元素为select_jquery如何获取第一个或最后一个子元素?
  3. iOS 本地DNS解析方法
  4. Linux系统中的函数
  5. Fluid 0.4 新版本正式发布
  6. ant构建项目迁移到gradle_Gradle构建工具
  7. 一种内核到用户空间的高效数据传输技术
  8. python网络编程需要学什么,python网络编程学习笔记(五):socket的一些补充 Python 网络编程需要学习哪些网络相关的知识...
  9. python mssqlserver_python for MSSQLserver
  10. 测试wcf的http和tcp绑定以及非wcf的命名管道传输文件速度对比
  11. [转载] python字典类方法
  12. python 实例对象 浅拷贝_Python 对象的深拷贝与浅拷贝 -- (转)
  13. Spring boot initialization failed for https://start.spring.io
  14. matlab 2014a安装方法以及解决打包失败的问题
  15. 问题解决-Visio2016和Office不能并行
  16. PHPWord通过docx模板替换标签,最终生成pdf文件
  17. R统计绘图-使用rgl或pca3D包绘制3DPCA图
  18. Python报错记录之“list indices must be integers or slices, not str”
  19. ⭐⭐⭐【DFS+理解题意】找出直系亲属
  20. 【visual studio】visual studio 2022 无法 复制黏贴

热门文章

  1. 试商法 素数探求 c语言,连续合数探求
  2. 用Python设计抢红包系统
  3. 盘点NBA历史上最强球员前十排行榜:沙奎尔·奥尼尔
  4. 网页调用迅雷下载文件
  5. 红警ol服务器维护,红警OL基地升级条件汇总 腾讯红警OL手游基地升级表
  6. 给textView设置文字渐变色
  7. 数组中出现次数超过一半的数字
  8. nSPack 手工脱壳过程
  9. 2020年jQuery被抛弃了吗
  10. Python自动玩俄罗斯方块小游戏