サーブレットでオンライン試験アプリケーションを開発しています。getParamter(-) メソッドを使用してラジオ ボタンの値を読み取っているときに、その表示/戻り値が「オン」になっているのは、一部のパラメーター名のパラメーター値です。それらの値をランダムに変更します。
たとえば、最初に要求すると、ラジオ ボタンの 2,5 の質問に対して「オン」の値が表示されます。2回目は、ラジオボタンの7,4の質問が「オン」になっています。
私のコードを確認し、私の間違いを教えてください
コード
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class ExamSrv extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
int j = 1;
PrintWriter pw = response.getWriter();
response.setContentType("text/html");
Connection con = null;
ResultSet resultSet = null;
Statement st = null;
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
con = DriverManager.getConnection("jdbc:odbc:accdsn");
st = con.createStatement();
resultSet = st.executeQuery("select qno,question,option1,option2,option3,option4 from Level1 where qno<=10");
pw.println("<form action=ansurl name=ans method=get>");
while (resultSet.next()) {
int k = resultSet.getInt(1);
pw.println(k + ").");
pw.println("<b><font size=3>" + resultSet.getString(2) + "</font></b><br><br>");
pw.println("<input type=radio name=opt" + j + " value=1 unchecked/>a)<b>" + resultSet.getString(3) +
"</b> ");
pw.println("<input type=radio name=opt" + j + " value =2 />b)<b>" + resultSet.getString(4) +
"</b> ");
pw.println("<input type=radio name=opt" + j + " vaule=3 />c)<b>" + resultSet.getString(5) +
"</b> ");
pw.println("<input type=radio name=opt" + j + " value=4 />d)<b>" + resultSet.getString(6) +
"</b><br><br><br> ");
j++;
}
pw.println("<input type=submit name=submit value=submit>");
pw.println("</form>");
} catch (Exception e) {
e.printStackTrace();
}
}
public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
doGet(req, res);
}
}
しかし、ブラウザに表示される「POST」としてフォームメソッドを変更すると、投稿はサポートされません..
読んでいる間
public class AnsSrv extends HttpServlet {
public void doGet(HttpServletRequest req, HttpServletResponse response) throws ServletException, IOException {
int j = 1, cnt = 0, fal = 0;
PrintWriter pw = response.getWriter();
response.setContentType("text/html");
Connection con = null;
ResultSet resultSet = null;
Statement st = null;
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
con = DriverManager.getConnection("jdbc:odbc:accdsn");
st = con.createStatement();
resultSet = st.executeQuery("select answer from Level1 where qno<=10");
while (resultSet.next()) {
if (req.getParameter("opt" + j).equals(resultSet.getString(1))
{
pw.println("opt"+j+"<br>"); //here it shows "on " value as on browser window
cnt++;
else
fal++;
j++;
}
pw.println("your marks are:" + (cnt - fal));
} catch (Exception e) {
e.printStackTrace();
}
}
public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
doGet(req, res);
}
}