麻辣家族討論版版's Archiver

小誌 發表於 2011-4-24 15:30

13-3-6 完整程式列表

[color=DarkRed][size=4][b]13-3-6   完整程式列表[/b][/size][/color]
Indoor.php[code]<?
//承接由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>[/code]

小誌 發表於 2011-4-24 15:31

Question.php[code]<?
//承接來自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] . "&nbsp&nbsp(" . $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>[/code]

小誌 發表於 2011-4-24 15:31

grad.php[code]<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]
       . "&nbsp&nbsp" . $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> [/code]

frank1232100 發表於 2013-1-8 17:32

我想請問一下31~51行 為什麼我選項都選正確答案 但是到grad.php顯示出來我的答案都是錯的

frank1232100 發表於 2013-1-8 17:38

$Sel=$_REQUEST["No" . $fielddatas[2]];
不是很了解這行,是我選的答案 他會存在$_REQUEST變數中在跟ANS對答案嗎?
那"NO"又是什麼呢?

頁: [1]

麻辣家族討論版版為 麻辣學園 網站成員  由 昱得資訊工作室 © Since 1993 所提供