您现在的位置: 微素材 >> 素材模板 >> 公众微信教程 >> 素材正文

《微信公众平台入门到精通》微信公众号教程(十八)

作者:佚名    素材来源:本站原创    点击数:    更新时间:2014/7/22

点击上面蓝色字 即可免费订阅,教您如何玩转微信!

您的微信名 (微信号:您的微信号)

昨天在ZTalk的技术群里有人在询问如何通过微信来做问答系统,他有1000道题目,想每次随机抽取10道题目让用户来回答,题目格式如图:




这个图是那位朋友的,从题目上来看,嘻嘻应该是运营商滴干活。关于答题系统之前有朋友提过,我一直没时间搞,其实做这个是非常简单的,趁这次机会干脆做下把源码提供给大家。


源码请在公众号里输入“微信代码”查看下载连接,然后将下载链接自己想办法搞到PC上然后再下载……建议先下载安装了再看文章,以下是注意事项:


1、与微信接口文件为wx_interface.php,大家可以将里面源代码复制粘贴到自己的接口文件里覆盖掉。


2、其他的文件全部上传到SAE的代码编辑里,有同名文件可以先删除原来文件再上传。


3、文件说明:


base-class.php 自定义函数,无需改动


wx_tpl.php 回复消息的模板,无需改动


question_manager.php 题库管理,无需改动


question_add.php 添加题目,无需改动


wx_interface.php 微信接口文件,根据自己实际修改名称


数据库创建方法请查看《微信公众平台入门到精通》Vol.15,创建代码在数据库.txt里。数据库分两张表,一张是问题表,一张是答题情况表,问题库的结构我就参照上图来了,答题情况表结构为序号、答题时间、回答的题目序号、答题消耗时间、答题错误次数。


一、题库建立


做问答系统首先是创建一个题库,一般的题目会有单选题、多选题和问答题,鉴于手机用户使用方便考虑,建议使用单选题。


添加题目的文件为question_add.php,大致的代码结构跟上次的通讯录后台一样,唯一多的是一个题目选项,题目选项我是用textarea这个控件,这是一个支持多行输入的输入框,并且可以直接存放到数据库,并且方便的按原来样子输出显示。



后台的效果如下图所示:


二、从题库随机提取不重复的N个问题


所有做问答系统的朋友都会问这个问题,如何从题库中随机的提取N个不重复的,今天在教程里就有这段代码。



其实Mysql本身是有自己的获取随机记录的函数,但是那个效率太低,如果数据库里记录超过几万,就会非常慢。


三、用户答题流程


用户答题整个程序都在wx_interface.php里,我在这里简单的介绍一下。




为了方便随时修改每次让用户回答的题目数,在第17行设了一个抽取题目数,修改这个数字就可以控制用户回答题目的数量。





一个友好的关注欢迎引导词是必不可少的,如何设置欢迎词请查阅第9期教程。用户输入“GO”后就进入了答题环节。


首先是从题库中提取N个不重复的随机题目,获取的题目是数组形式,我们将这些题目用serialize序列化后保存到缓存里(命名为:微信用户OPENID_question_data),接下来用户答题就是从这个缓存里获取。


设定答题的当前序号为setp_1并保存到缓存,用户互动时就通过判断这个缓存是否有值决定是否是答题状态。


设定开始的时间和初始化错误次数并保存到缓存,用来记录用户的一些答题数据。




由于答题是一个循环的过程,因此我们在用户输入go的时候只是把相关数据初始化放入缓存并不输出问题,而是单独写一个每次答题都会用到的循环过程来做答题,这个循环过程包括:


1、从缓存中取出数据




2、判断当前是否在答题状态,即question_order这个缓存是否有值,同时提取当前是第几题赋值给$now_order。




3、如果当前不是第一题,则表示这个时候用户发送的回复消息应该是答案,那么检查答案是否正确,如果不正确提示错误并退出程序让用户继续回答当前题目。




4、判断当前是否是最后一题,如果是则保存用户答题数据,清空所有缓存,提示用户答题完成信息。





5、当前问题回答正确且没有到最后一题的,系统提取下一个题目输出,同时增加答题序号的步长。






6、一些附加功能,比如输入best查询自己的最好成绩,输入history查询自己最近10次答题记录。



如果想做互动的话还可以让做个查看比你快的用户有多少等等,自由发挥吧。