微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

 

这个图是那位朋友的,从题目上来看,嘻嘻应该是运营商滴干活。

答题系统源码

建议先下载安装了再看文章,以下是注意事项:

 

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这个控件,这是一个支持多行输入的输入框,并且可以直接存放到数据库,并且方便的按原来样子输出显示。

 

微信公众号教程(17)问答系统

后台的效果如下图所示:

微信公众号教程(17)问答系统

微信公众号教程(17)问答系统

 

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

 

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

 

微信公众号教程(17)问答系统

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

 

三、用户答题流程

 

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

 

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

微信公众号教程(17)问答系统

 

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

 

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

 

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

 

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

 

微信公众号教程(17)问答系统

 

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

 

1、从缓存中取出数据

 

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

 

微信公众号教程(17)问答系统

 

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

 

微信公众号教程(17)问答系统

微信公众号教程(17)问答系统

 

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

微信公众号教程(17)问答系统

上一篇:yml语法01


下一篇:frp实现p2p远程连接桌面,非服务器中转