原文:http://www.cnblogs.com/imaker/p/6252617.html
昨天在ZTalk的技术群里有人在询问如何通过微信来做问答系统,他有1000道题目,想每次随机抽取10道题目让用户来回答,题目格式如图:
这个图是那位朋友的,从题目上来看,嘻嘻应该是运营商滴干活。
答题系统源码
建议先下载安装了再看文章,以下是注意事项:
1、与微信接口文件为wx_interface.php,大家可以将里面源代码复制粘贴到自己的接口文件里覆盖掉。
2、其他的文件全部上传到SAE的代码编辑里,有同名文件可以先删除原来文件再上传。
3、文件说明:
base-class.php 自定义函数,无需改动
wx_tpl.php 回复消息的模板,无需改动
question_manager.php 题库管理,无需改动
question_add.php 添加题目,无需改动
wx_interface.php 微信接口文件,根据自己实际修改名称
数据库创建,创建代码在数据库.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次答题记录。
如果想做互动的话还可以让做个查看比你快的用户有多少等等,自由发挥吧。