Maison  >  Article  >  développement back-end  >  php+mysql développe la banque de questions en ligne et le système de création de questions en ligne le plus simple

php+mysql développe la banque de questions en ligne et le système de création de questions en ligne le plus simple

不言
不言original
2018-04-28 14:03:419726parcourir

Cet article présente principalement php+mysql pour développer la banque de questions en ligne et le système de création de questions en ligne le plus simple, qui a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer

. Banque de questions , elle est très nécessaire pour les établissements d'enseignement, les écoles et l'éducation en ligne. Il existe également de nombreux systèmes de banques de questions en ligne tiers sur Internet. Cependant, ce cas permettra aux personnes dans le besoin de comprendre les idées de développement de la banque de questions. C'est en fait très simple, rien de plus qu'une validation de formulaire, une validation de base de données.

1. Créez d'abord les données du formulaire

2. Soumettez les données du formulaire à la page de vérification du formulaire via get ou post, et faites-les correspondre avec la base de données

3. le résultat, répondez Vrai ou Faux

Construisez le formulaire :

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[&#39;page&#39;]?$_GET[&#39;page&#39;]: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"];
    }
?>
<p 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>
</p>
    <br/>
    <?php
    echo "<p id=&#39;tiku&#39;>";
        echo "<ul>";
            echo "<li><a href=&#39;next.php?page=$prepage&#39;>上一题</a></li>";
            echo "<li><a href=&#39;next.php?page=$nextpage&#39;>下一题</a></li>";
        echo "</ul>";
    echo "<p>";
    echo "<br/>";
    echo "<p class=&#39;fenye_tips&#39;>共".$allpage."道题,当前是第".$page."题</p>";
    echo "<br/><br/>";
    echo "</p>";
    ?>
</body>
</html>

Formulaire de réception

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(&#39;请选择一个答案!&#39;);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(&#39;正确!得5分!&#39;);location.href=&#39;next.php?page=$next_id&#39;;</script>";
        }else{
            echo "<script>alert(&#39;错了!扣5分!&#39;);history.go(-1);</script>";
        }
    }
}
?>

Configuration de la base de données

config.php

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

next.php

Question suivante

<!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[&#39;page&#39;]?$_GET[&#39;page&#39;]: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"];
    }
?>
<p 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>
</p>
    <br/>
    <?php
    echo "<p id=&#39;tiku&#39;>";
        echo "<ul>";
            echo "<li><a href=&#39;next.php?page=$prepage&#39;>上一题</a></li>";
            echo "<li><a href=&#39;next.php?page=$nextpage&#39;>下一题</a></li>";
        echo "</ul>";
    echo "<p>";
    echo "<br/>";
    echo "<p class=&#39;fenye_tips&#39;>共".$allpage."道题,当前是第".$page."题</p>";
    echo "<br/><br/>";
    echo "</p>";
    ?>
</body>
</html>

Structure de la base de données

titre --------Titre
answer_A -----Réponse A
answer_B -----Réponse B
answer_C - ---- Réponse C
réponse_D -----Réponse D
vrai ---------Réponse correcte
score --------Score


Recommandations associées :

php+mysql réalise une page Web simple de connexion, d'enregistrement et de modification de mot de passe


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn