Board logo

標題: 13-3-6 完整程式列表 [打印本頁]

作者: 小誌    時間: 2011-4-24 15:30     標題: 13-3-6 完整程式列表

13-3-6   完整程式列表
Indoor.php
  1. <?
  2. //承接由Indoor表單傳來的學號、姓名資料
  3. @$studentname=$_REQUEST["studentname"];
  4. @$number=$_REQUEST["number"];
  5. $Msg="";
  6. //如果Indoor表單傳來的學號、姓名資料不是空白的
  7. //就進行與資料庫中受測學生資料進行比對
  8. IF (($studentname!="") && ($number!="")):
  9. //連結MySQL Server
  10.     $conn = mysql_connect("localhost", "root", "12345a");
  11. //選擇資料庫
  12.     mysql_select_db("exam", $conn);
  13. //指定提取資料的校對字元表
  14.     mysql_query("set character set big5");
  15. //提取資料的SQL命令字串
  16.    $SQL="SELECT * From student where 學號='" .$number . "' and 姓名='" .$studentname . "'";
  17. //進行資料查詢
  18. $RS=mysql_query($SQL);
  19. //如果姓名學號驗證無誤就進入試卷網頁
  20.    if ($Result=mysql_fetch_array($RS))
  21. {
  22. header("Location: question.php?" . $_SERVER["QUERY_STRING"]);
  23. }
  24. else
  25. {   
  26. //如果找不到對應的學號與姓名就顯示錯誤訊息
  27.    IF ($Msg=="")
  28.    $Msg="姓名或學號輸入有錯誤!";
  29. }
  30. EndIf;
  31. ?>

  32. <html>
  33. <head>
  34. <meta http-equiv="Content-Type" content="text/html; charset=big5">
  35. <title>線上考試-試場大門</title>
  36. <script language="vbscript">
  37. <!--
  38. <!-- 檢查有沒有輸入資料 -->
  39. Function datacheck
  40. <!--利用VB 檢驗字串長度的Len函數驗證欄位資料是否填寫-->
  41. IF Len(document.indoor.studentname.value)=0 or Len(document.indoor.number.value)=0 then
  42. <!--如果有欄位沒有填寫則秀出警告視窗-->
  43. msg="請輸入資料!"
  44. MsgBox msg,vbExclamation,"錯誤!"
  45. Exit Function
  46. End IF
  47. <!--如果欄位資料都有填寫則觸發身分驗證的PHP程式-->
  48. indoor.Submit
  49. End Function
  50. -->
  51. </script>
  52. </head>
  53. <body>
  54. <!-- 輸入資料的表單 -->
  55. <p align="center"><font color="#FF0000" size="6" face="新細明體">線上考試-試場大門</font></p>
  56. <!--受測學生所填的資料不正確將會出現一段錯誤訊息-->
  57. <center><font color="red"><?=$Msg;?></font></center>
  58. <form method="get" name="indoor" >
  59.   <div align="center">
  60.     <table border="0" width="60%">
  61.       <tr>
  62.         <td width="50%">
  63.           <p align="right"><font color="#0000FF">姓名:</font></td>
  64.         <center>
  65.         <td width="50%"><input type="text" name="studentname" size="10" value="<?=$studentname;?>"></td>
  66.         </tr>
  67.       <tr>
  68.         <td width="50%">
  69.           <p align="right"><font color="#0000FF">學號:</font></td>
  70.         <td width="50%"><input type="number" name="number" size="10" value="<?=$number;?>"></td>
  71.         </tr>
  72.         <tr>
  73.           <td width="100%" colspan="2">
  74.             <p align="center"><input type="button" value="進入考場" onclick="datacheck">
  75.             <input type="reset" value="重新輸入"></td>
  76.         </tr>
  77.       </table>
  78.     </center>
  79.   </div>
  80. </form>
  81. </body>
  82. </html>
複製代碼

作者: 小誌    時間: 2011-4-24 15:31

Question.php
  1. <?
  2. //承接來自Indoor.php的學號、姓名資料
  3. $studentname=$_REQUEST["studentname"];
  4. $number=$_REQUEST["number"];
  5. //開啟exam資料庫中的ask(題目)資料表
  6. //連結MySQL Server
  7.     $conn = mysql_connect("localhost", "root", "12345a");
  8. //選擇資料庫
  9.     mysql_select_db("exam", $conn);
  10. //指定提取資料的校對字元表
  11.     mysql_query("set character set big5");
  12. //提取資料的SQL命令字串
  13.    $SQL="Select * From ask Order by 題號";
  14. //進行資料查詢
  15. $RS=mysql_query($SQL);
  16. ?>
  17. <HTML>
  18. <HEAD>
  19. <meta http-equiv="Content-Type" content="text/html; charset=big5">
  20. <TITLE>線上考試-試卷網頁</TITLE>
  21. </HEAD>
  22. <BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080">
  23. <div align="center"><font color="red" face="新細明體" size="6">線上考試-試卷網頁</font></div>
  24. <form action="grad.php" method="get">
  25. <input type="hidden" name="studentname" value="<?=$studentname;?>">
  26. <input type="hidden" name="number" value="<?=$number;?>">  
  27. <?
  28. //顯示考題
  29. //讀取資料表的資料錄直到資料錄全度讀取完畢
  30. //將資料錄轉換為欄位陣列集合
  31. While (($fielddatas=mysql_fetch_array($RS)))
  32. {
  33. //顯示題目及配分  
  34.   echo "<hr size=1><font color=blue>" . $fielddatas[2]
  35.       . "、" . $fielddatas[3] . "&nbsp&nbsp(" . $fielddatas[9] . "分)</font><br>";
  36. //顯示備選的答案項目                 
  37.   For($I=1;$I<=4;$I++)
  38.     {
  39.     echo "<font color=red>(" . $I . ")</font><input type=Radio "
  40.     . "name='No" . $fielddatas[2] . "' value=" . $I . ">" . $fielddatas["答案" .$I] ."<br>";
  41.     }
  42. }
  43. ?>
  44. <hr size="1">
  45. <div align="center"><input type="submit" value="交卷"></div>
  46. </form>
  47. </BODY>
  48. </HTML>
複製代碼

作者: 小誌    時間: 2011-4-24 15:31

grad.php
  1. <HTML>
  2. <HEAD>
  3. <meta http-equiv="Content-Type" content="text/html; charset=big5">
  4. <TITLE>線上考試-成績批改</TITLE>
  5. </HEAD>
  6. <BODY>
  7. <div align=center>
  8. <font color=green face=新細明體 size=6>線上考試-成績批改</font>
  9. </div>
  10. <?
  11. //承接來自question.php的資料
  12. $studentname=$_REQUEST["studentname"];
  13. $number=$_REQUEST["number"];
  14. //開啟exam資料庫中的ask考題資料表
  15. //在此開啟資料庫是用來讀取答案與寫入計算後的成績
  16. //開啟exam資料庫中的ask(題目)資料表
  17. //連結MySQL Server
  18.     $conn = mysql_connect("localhost", "root", "12345a");
  19. //選擇資料庫
  20.     mysql_select_db("exam", $conn);
  21. //指定提取資料的校對字元表
  22.     mysql_query("set character set big5");
  23. //提取資料的SQL命令字串
  24.    $SQL="Select * From ask Order by 題號";
  25. //進行資料查詢
  26. $RS=mysql_query($SQL);
  27. //先將計算的總分設為0   
  28.    $Score=0;

  29. //將正確答案及受測學生選的答案一起顯示比對   
  30. While (($fielddatas=mysql_fetch_array($RS)))
  31. {
  32.    $Sel=$_REQUEST["No" . $fielddatas[2]];
  33.    $Ans=$fielddatas[8];
  34. //計算成績,答對的題目加上該題應得分數
  35. //同時告知該題目是答對還是答錯
  36.    IF (trim($Sel)==trim($Ans))
  37.        {
  38.           $Score=$Score+$fielddatas[9];
  39.           $RM="-->答對";
  40.         }
  41.    ELSE
  42.         {
  43.           $RM="-->答錯";
  44.         }
  45.    $Ans=$fielddatas[$Ans+3];
  46.    $yourans=$fielddatas[$Sel+3];
  47. //將試題批改的結果輸出至網頁中
  48.    echo "<hr size=1>" . $fielddatas[2]
  49.        . "&nbsp&nbsp" . $fielddatas[3] . "<font color=red>" . $RM ."</font><br>";
  50. }


  51. //開啟exam中的student資料表,顯示受測學生的成績  
  52. //將批改後的受測學生成績存入資料庫中
  53. $SQL="update student set 分數=" . $Score . " where 學號='". $number . "' and 姓名='" .$studentname . "'";
  54. mysql_query($SQL);
  55. ?>
  56. <hr size="1">
  57. <!-- 顯示應考學生的資料 -->
  58. <table align="center" border="0" width="50%">
  59. <tr><td align="center" width="50%"><font color="blue">姓名:<?=$studentname;?></font></td>
  60. <td align="center" width="50%"><font color="blue">學號:<?=$number;?></font></td></tr>
  61. </table>
  62. <!-- 顯示應考學生的成績 -->
  63. <table align="center" border="1" width="50%">
  64. <tr><td align="center" width="50%">考試進度</td>
  65. <td align="center" width="50%">分數</td></tr>
  66. <tr><td align="center">本次測驗成績</td><td align="center">
  67. <!--將成積不及格的分數以紅色顯示-->
  68. <?
  69.   IF ($Score<50)
  70.   echo "<font color=red>" . $Score . "分,死當</font>";
  71.   ELSEIF ($Score<60)
  72.   echo "<font color=red>" . $Score . "分,補考</font>";
  73.   ELSE
  74.   echo $Score . "分,及格";
  75. ?>
  76. </td></tr>
  77. </table>
  78. <hr size="1">
  79. <p>
  80. <!-- 重新填寫測驗卷 -->
  81. </p>
  82. <div align="center">
  83. <a href="indoor.php?studentname=<?=$studentname;?>&number=<?=$number;?>">[再考一次]</a>
  84. </div>
  85. </BODY>
  86. </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/)