题库,对于教育机构,学校,在线教育,是很有必要的,网上也有不少的第三方在线题库系统,但是本次案例,会让有需要的人了解题库的开发思路,其实很简单,无非就是一个表单验证,数据库验证。

1、先构建表单数据
2、把表单数据通过get或者post方式提交到表单验证页面,和数据库进行匹配
3、返回结果,答案正确或者错误

构建表单:
index.php

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0" />
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="format-detection" content="telephone=no">
<title>题库</title>
<style type="text/css">
*{list-style: none;margin:0px;padding: 0px;}
#tiku{
width: 300px;
margin:10px auto;
} #tiku ul li{
float: left;
}
</style>
</head>
<body>
<?php
//获取数据库配置
require_once("config.php");
//连接数据库
$con = mysql_connect($host,$username,$password);
//设置数据库字符集
mysql_query("SET NAMES UTF8");
//查询数据库
mysql_select_db($db, $con);
//查询数据库
//获取最新的1条数据
$all = mysql_num_rows(mysql_query("select * from $tb"));
//定义分页所需的参数
$lenght=1; //每页显示的数量
@$page=$_GET['page']?$_GET['page']:1; //当前页
$offset=($page-1)*$lenght; //每页起始行编号
$allpage=ceil($all/$lenght); //所有的页数-总数页
$prepage=$page-1; //上一页
if($page==1){
$prepage=1; //特殊的是当前页是1时上一页就是1
}
$nextpage=$page+1;
if($page==$allpage){
$nextpage=$allpage; //特殊的是最后页是总数页时下一页就是总数页
}
$sql="select * from $tb order by id ASC limit {$offset},{$lenght}";
$rest=mysql_query($sql);
while($row = mysql_fetch_assoc($rest))
{
$id = $row["id"];
$title = $row["title"];
$A = $row["answer_A"];
$B = $row["answer_B"];
$C = $row["answer_C"];
$D = $row["answer_D"];
$true = $row["true"];
$score = $row["score"];
}
?>
<div id="tiku">
<form action="check.php" method="get">
<p><?php echo $title;?></p>
<input type="radio" name="xuanxiang" value="<?php echo $A;?>">A:<?php echo $A;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $B;?>">B:<?php echo $B;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $C;?>">C:<?php echo $C;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $D;?>">D:<?php echo $D;?><br><br>
<input type="hidden" name="id" value="<?php echo $id;?>">
<button>提交</button>
</form>
</div>
<br/>
<?php
echo "<div id='tiku'>";
echo "<ul>";
echo "<li><a href='next.php?page=$prepage'>上一题</a></li>";
echo "<li><a href='next.php?page=$nextpage'>下一题</a></li>";
echo "</ul>";
echo "<div>";
echo "<br/>";
echo "<p class='fenye_tips'>共".$allpage."道题,当前是第".$page."题</p>";
echo "<br/><br/>";
echo "</div>";
?>
</body>
</html>

表单接收
check.php

<?php
header("Content-type:text/html;charset=utf-8");
//获取数据库配置
require_once("config.php");
//连接数据库
$con = mysql_connect($host,$username,$password);
//设置数据库字符集
mysql_query("SET NAMES UTF8");
//查询数据库
mysql_select_db($db, $con);
//获取数据
$xuanxiang = $_GET["xuanxiang"];
$id = $_GET["id"];
if (empty($xuanxiang)) {
echo "<script>alert('请选择一个答案!');history.go(-1);</script>";
}else{
//查询数据库
$result = mysql_query("SELECT * FROM $tb WHERE id =".$id);
while($row = mysql_fetch_array($result))
{
$true = $row["true"];
$next_id = $id+1;
if($xuanxiang == $true){
echo "<script>alert('正确!得5分!');location.href='next.php?page=$next_id';</script>";
}else{
echo "<script>alert('错了!扣5分!');history.go(-1);</script>";
}
}
}
?>

数据库配置
config.php

<?php
//配置文件 - BY TANKING
$host="数据库地址";
$username="账号";
$password="密码";
$db="数据库名";
$tb = "表名";
?>

next.php
下一题

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0" />
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="format-detection" content="telephone=no">
<title>题库</title>
<style type="text/css">
*{list-style: none;margin:0px;padding: 0px;}
#tiku{
width: 300px;
margin:10px auto;
} #tiku ul li{
float: left;
}
</style>
</head>
<body>
<?php
//获取数据库配置
require_once("config.php");
//连接数据库
$con = mysql_connect($host,$username,$password);
//设置数据库字符集
mysql_query("SET NAMES UTF8");
//查询数据库
mysql_select_db($db, $con);
//查询数据库
//获取最新的1条数据
$all = mysql_num_rows(mysql_query("select * from $tb"));
//定义分页所需的参数
$lenght=1; //每页显示的数量
@$page=$_GET['page']?$_GET['page']:1; //当前页
$offset=($page-1)*$lenght; //每页起始行编号
$allpage=ceil($all/$lenght); //所有的页数-总数页
$prepage=$page-1; //上一页
if($page==1){
$prepage=1; //特殊的是当前页是1时上一页就是1
}
$nextpage=$page+1;
if($page==$allpage){
$nextpage=$allpage; //特殊的是最后页是总数页时下一页就是总数页
}
$sql="select * from $tb order by id ASC limit {$offset},{$lenght}";
$rest=mysql_query($sql);
while($row = mysql_fetch_assoc($rest))
{
$id = $row["id"];
$title = $row["title"];
$A = $row["answer_A"];
$B = $row["answer_B"];
$C = $row["answer_C"];
$D = $row["answer_D"];
$true = $row["true"];
$score = $row["score"];
}
?>
<div id="tiku">
<form action="check.php" method="get">
<p><?php echo $title;?></p>
<input type="radio" name="xuanxiang" value="<?php echo $A;?>">A:<?php echo $A;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $B;?>">B:<?php echo $B;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $C;?>">C:<?php echo $C;?><br>
<input type="radio" name="xuanxiang" value="<?php echo $D;?>">D:<?php echo $D;?><br><br>
<input type="hidden" name="id" value="<?php echo $id;?>">
<button>提交</button>
</form>
</div>
<br/>
<?php
echo "<div id='tiku'>";
echo "<ul>";
echo "<li><a href='next.php?page=$prepage'>上一题</a></li>";
echo "<li><a href='next.php?page=$nextpage'>下一题</a></li>";
echo "</ul>";
echo "<div>";
echo "<br/>";
echo "<p class='fenye_tips'>共".$allpage."道题,当前是第".$page."题</p>";
echo "<br/><br/>";
echo "</div>";
?>
</body>
</html>

数据库结构

title --------题目
answer_A -----答案A
answer_B -----答案B
answer_C -----答案C
answer_D -----答案D
true ---------正确答案
score --------得分

php+mysql开发一个最简单的在线题库,在线做题系统!的更多相关文章

  1. jQuery框架开发一个最简单的幻灯效果

    在线演示 在这个课程中,我们将介绍如何使用jQuery来开发一个最简单的图片幻灯效果. 立刻观看互动课程:jQuery框架开发一个最简单的幻灯效果 阅读原文:jQuery框架开发一个最简单的幻灯效果

  2. Hello,Cardboard!!-如何开发一个最简单的Cardboard虚拟现实应用(一)

    [原创文章,转载请注明出处,谢谢 !] 温馨提醒,本篇第一节主要介绍cardboard虚拟现实系统的组成,如果只想看如何开发的具体步骤请直接跳到第二节^_^ 前述:恕我啰嗦一下,主要照顾对cardbo ...

  3. 使用开源框架Sqlsugar结合mysql开发一个小demo

    一.Sqlsugar简介 1.性能上有很大优势 sqlsugar是性能最好的ORM之一,具有超越Dapper的性能 ,走的是EMIT够构中间语言动态编译到程序集,完成高性能的实体绑定,达到原生水平. ...

  4. 开发一个最简单的Cardboard虚拟现实应用(四)做一个Cardboard第一人称控制器

    [开源互助-原创文章,转载请说明出处]第三帖中已经创建了一个cardboard自带的demo应用,但它是不能移动的,玩家只能站在原地,通过头部转动来观察四周,除此之外,玩家并没有更多的手段与游戏场景进 ...

  5. 开发一个 app 有多难?

    171 个回答 默认排序​ 道衍天机 有事情的加微信1293190838找我 1,150 人赞同了该回答 ----------------------------------------------- ...

  6. 腾讯出品的一个超棒的 Android UI 库

    腾讯出品的一个超棒的 Android UI 库 相信做 Android 久了大家都会有种体会,那就是 Android 开发相对于前端开发来说统一的 UI 开源库比较少.造成这种现象的原因一方面是大多数 ...

  7. 如何开发一个简单的HTML5 Canvas 小游戏

    原文:How to make a simple HTML5 Canvas game 想要快速上手HTML5 Canvas小游戏开发?下面通过一个例子来进行手把手教学.(如果你怀疑我的资历, A Wiz ...

  8. 我是怎么开发一个小型java在线学习网站的

    2016/1/27 11:55:14 我是怎么开发一个小型java在线学习网站的 一直想做一个自己的网站(非博客),但是又不知道做什么内容的好,又一次看到了w3schools,就萌发了开发一个在线ja ...

  9. python 开发一个支持多用户在线的FTP

    ### 作者介绍:* author:lzl### 博客地址:* http://www.cnblogs.com/lianzhilei/p/5813986.html### 功能实现 作业:开发一个支持多用 ...

随机推荐

  1. python_4

    1.迭代器:通过iter()方法获得了list的迭代对象,然后就可以通过next()方法来访问list中的元素了,当容器中没有可访问元素时,会抛出StopIteration异常终止迭代器 data = ...

  2. 006.前端开发知识,前端基础CSS(2020-01-21)

    来源:第五天  01盒子水平居中 一.盒子中文字控制: 1.text-align: center; /*可以让盒子内容(文字 行内元素 行内块元素)居中对齐*/ 二.让盒子水平居中对齐: 方法1.ma ...

  3. Idea mac

    Idea 的破解 http://idea.lanyus.com/ Idea 的常用配置 模版及模版的使用 创建 JavaWeb 或 Module 关联数据库 版本控制 断点调试 配置 maven 其他 ...

  4. django框架基础-django模板语言-长期维护

    ##################     常用的模板语言       ####################### # django的模板语言, # # 只需要记两种特殊符号: # # {{ } ...

  5. va_list、va_start和va_end使用

    我们知道va_start,va_arg,va_end是在stdarg.h中被定义成宏的,由于1.硬件平台的不同 2.编译器的不同,所以定义的宏也有所不同. 在ANSI C中,这些宏的定义位于stdar ...

  6. mysql挖掘与探索------第2章 索引1-1

    1索引作用 说起提高数据库性能,索引是最物美价廉的东西了.不用加内存,不用改程序,不用调sql,只要执行个正确的’create index’,查询速度就可能提高百倍千倍,这可真有诱惑力.可是天下没有免 ...

  7. Java IO: 其他字符流(下)

    作者: Jakob Jenkov 译者: 李璟(jlee381344197@gmail.com) 本小节会简要概括Java IO中的PushbackReader,LineNumberReader,St ...

  8. RAM子账户登录DMS对库进行管理

    前言:阿里云账户是个权限很大的账户,有时候为了不让更多的人知道,但是又必须让别人管理里面某个模块的功能的时候,RAM子账户就显得很重要,所以设置子账户的权限就很有必要了,下面简单设置两种权限(dms上 ...

  9. leetcode第32题:最长有效括号

    关于括号匹配或生成的问题,首先想到的是栈. 本题易错点:返回值为连续有效()的长度, 即()(()这种情况下,返回值为2 # 去除字符串首的连续)和字符串尾得连续( while True: if no ...

  10. 图的DFS。。类似树的DFS

    Depth-First Search (DFS) Depth-first search (DFS) is an algorithm for traversing or searching tree o ...