標題:
13-3-6 完整程式列表
[打印本頁]
作者:
小誌
時間:
2011-4-24 15:30
標題:
13-3-6 完整程式列表
13-3-6 完整程式列表
Indoor.php
<?
//承接由Indoor表單傳來的學號、姓名資料
@$studentname=$_REQUEST["studentname"];
@$number=$_REQUEST["number"];
$Msg="";
//如果Indoor表單傳來的學號、姓名資料不是空白的
//就進行與資料庫中受測學生資料進行比對
IF (($studentname!="") && ($number!="")):
//連結MySQL Server
$conn = mysql_connect("localhost", "root", "12345a");
//選擇資料庫
mysql_select_db("exam", $conn);
//指定提取資料的校對字元表
mysql_query("set character set big5");
//提取資料的SQL命令字串
$SQL="SELECT * From student where 學號='" .$number . "' and 姓名='" .$studentname . "'";
//進行資料查詢
$RS=mysql_query($SQL);
//如果姓名學號驗證無誤就進入試卷網頁
if ($Result=mysql_fetch_array($RS))
{
header("Location: question.php?" . $_SERVER["QUERY_STRING"]);
}
else
{
//如果找不到對應的學號與姓名就顯示錯誤訊息
IF ($Msg=="")
$Msg="姓名或學號輸入有錯誤!";
}
EndIf;
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<title>線上考試-試場大門</title>
<script language="vbscript">
<!--
<!-- 檢查有沒有輸入資料 -->
Function datacheck
<!--利用VB 檢驗字串長度的Len函數驗證欄位資料是否填寫-->
IF Len(document.indoor.studentname.value)=0 or Len(document.indoor.number.value)=0 then
<!--如果有欄位沒有填寫則秀出警告視窗-->
msg="請輸入資料!"
MsgBox msg,vbExclamation,"錯誤!"
Exit Function
End IF
<!--如果欄位資料都有填寫則觸發身分驗證的PHP程式-->
indoor.Submit
End Function
-->
</script>
</head>
<body>
<!-- 輸入資料的表單 -->
<p align="center"><font color="#FF0000" size="6" face="新細明體">線上考試-試場大門</font></p>
<!--受測學生所填的資料不正確將會出現一段錯誤訊息-->
<center><font color="red"><?=$Msg;?></font></center>
<form method="get" name="indoor" >
<div align="center">
<table border="0" width="60%">
<tr>
<td width="50%">
<p align="right"><font color="#0000FF">姓名:</font></td>
<center>
<td width="50%"><input type="text" name="studentname" size="10" value="<?=$studentname;?>"></td>
</tr>
<tr>
<td width="50%">
<p align="right"><font color="#0000FF">學號:</font></td>
<td width="50%"><input type="number" name="number" size="10" value="<?=$number;?>"></td>
</tr>
<tr>
<td width="100%" colspan="2">
<p align="center"><input type="button" value="進入考場" onclick="datacheck">
<input type="reset" value="重新輸入"></td>
</tr>
</table>
</center>
</div>
</form>
</body>
</html>
複製代碼
作者:
小誌
時間:
2011-4-24 15:31
Question.php
<?
//承接來自Indoor.php的學號、姓名資料
$studentname=$_REQUEST["studentname"];
$number=$_REQUEST["number"];
//開啟exam資料庫中的ask(題目)資料表
//連結MySQL Server
$conn = mysql_connect("localhost", "root", "12345a");
//選擇資料庫
mysql_select_db("exam", $conn);
//指定提取資料的校對字元表
mysql_query("set character set big5");
//提取資料的SQL命令字串
$SQL="Select * From ask Order by 題號";
//進行資料查詢
$RS=mysql_query($SQL);
?>
<HTML>
<HEAD>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<TITLE>線上考試-試卷網頁</TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080">
<div align="center"><font color="red" face="新細明體" size="6">線上考試-試卷網頁</font></div>
<form action="grad.php" method="get">
<input type="hidden" name="studentname" value="<?=$studentname;?>">
<input type="hidden" name="number" value="<?=$number;?>">
<?
//顯示考題
//讀取資料表的資料錄直到資料錄全度讀取完畢
//將資料錄轉換為欄位陣列集合
While (($fielddatas=mysql_fetch_array($RS)))
{
//顯示題目及配分
echo "<hr size=1><font color=blue>" . $fielddatas[2]
. "、" . $fielddatas[3] . "  (" . $fielddatas[9] . "分)</font><br>";
//顯示備選的答案項目
For($I=1;$I<=4;$I++)
{
echo "<font color=red>(" . $I . ")</font><input type=Radio "
. "name='No" . $fielddatas[2] . "' value=" . $I . ">" . $fielddatas["答案" .$I] ."<br>";
}
}
?>
<hr size="1">
<div align="center"><input type="submit" value="交卷"></div>
</form>
</BODY>
</HTML>
複製代碼
作者:
小誌
時間:
2011-4-24 15:31
grad.php
<HTML>
<HEAD>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<TITLE>線上考試-成績批改</TITLE>
</HEAD>
<BODY>
<div align=center>
<font color=green face=新細明體 size=6>線上考試-成績批改</font>
</div>
<?
//承接來自question.php的資料
$studentname=$_REQUEST["studentname"];
$number=$_REQUEST["number"];
//開啟exam資料庫中的ask考題資料表
//在此開啟資料庫是用來讀取答案與寫入計算後的成績
//開啟exam資料庫中的ask(題目)資料表
//連結MySQL Server
$conn = mysql_connect("localhost", "root", "12345a");
//選擇資料庫
mysql_select_db("exam", $conn);
//指定提取資料的校對字元表
mysql_query("set character set big5");
//提取資料的SQL命令字串
$SQL="Select * From ask Order by 題號";
//進行資料查詢
$RS=mysql_query($SQL);
//先將計算的總分設為0
$Score=0;
//將正確答案及受測學生選的答案一起顯示比對
While (($fielddatas=mysql_fetch_array($RS)))
{
$Sel=$_REQUEST["No" . $fielddatas[2]];
$Ans=$fielddatas[8];
//計算成績,答對的題目加上該題應得分數
//同時告知該題目是答對還是答錯
IF (trim($Sel)==trim($Ans))
{
$Score=$Score+$fielddatas[9];
$RM="-->答對";
}
ELSE
{
$RM="-->答錯";
}
$Ans=$fielddatas[$Ans+3];
$yourans=$fielddatas[$Sel+3];
//將試題批改的結果輸出至網頁中
echo "<hr size=1>" . $fielddatas[2]
. "  " . $fielddatas[3] . "<font color=red>" . $RM ."</font><br>";
}
//開啟exam中的student資料表,顯示受測學生的成績
//將批改後的受測學生成績存入資料庫中
$SQL="update student set 分數=" . $Score . " where 學號='". $number . "' and 姓名='" .$studentname . "'";
mysql_query($SQL);
?>
<hr size="1">
<!-- 顯示應考學生的資料 -->
<table align="center" border="0" width="50%">
<tr><td align="center" width="50%"><font color="blue">姓名:<?=$studentname;?></font></td>
<td align="center" width="50%"><font color="blue">學號:<?=$number;?></font></td></tr>
</table>
<!-- 顯示應考學生的成績 -->
<table align="center" border="1" width="50%">
<tr><td align="center" width="50%">考試進度</td>
<td align="center" width="50%">分數</td></tr>
<tr><td align="center">本次測驗成績</td><td align="center">
<!--將成積不及格的分數以紅色顯示-->
<?
IF ($Score<50)
echo "<font color=red>" . $Score . "分,死當</font>";
ELSEIF ($Score<60)
echo "<font color=red>" . $Score . "分,補考</font>";
ELSE
echo $Score . "分,及格";
?>
</td></tr>
</table>
<hr size="1">
<p>
<!-- 重新填寫測驗卷 -->
</p>
<div align="center">
<a href="indoor.php?studentname=<?=$studentname;?>&number=<?=$number;?>">[再考一次]</a>
</div>
</BODY>
</HTML>
複製代碼
作者:
frank1232100
時間:
2013-1-8 17:32
我想請問一下31~51行 為什麼我選項都選正確答案 但是到grad.php顯示出來我的答案都是錯的
作者:
frank1232100
時間:
2013-1-8 17:38
$Sel=$_REQUEST["No" . $fielddatas[2]];
不是很了解這行,是我選的答案 他會存在$_REQUEST變數中在跟ANS對答案嗎?
那"NO"又是什麼呢?
歡迎光臨 麻辣家族討論版版 (http://forum.twbts.com/)