0

我正在为只有 5 个问题的在线考试创建一个 3 层 Web 应用程序。我使用 html 并设计了一个 servlet 来将数据发布到我命名为“test”的 mysql 数据库,表是“st1”。我使用具有内置 MyEclipse Tomcat 6.0.13 的 MyEclipse Blue 8.6.1。doPost()方法中servlet的编码如下:

try
{
    String url="jdbc:mysql://localhost:3306/test";
    Class.forName("com.mysql.jdbc.Driver");
    connect=DriverManager.getConnection(url,"root","root");
    message="Connection Sucessfull";
}
catch(ClassNotFoundException cnfex){
    cnfex.printStackTrace();
}
catch(SQLException sqlex){
    sqlex.printStackTrace();
}
catch(Exception excp){
    excp.printStackTrace();
}
seat_no=request.getParameter("Seat_No");
name=request.getParameter("Name");
ans1=request.getParameter("group1");
ans2=request.getParameter("group2");
ans3=request.getParameter("group3");
ans4=request.getParameter("group4");
ans5=request.getParameter("group5");
if(ans1.equals("True"))
    Total+=2;
if(ans2.equals("False"))
    Total+=2;
if(ans3.equals("True"))
    Total+=2;
if(ans4.equals("False"))
    Total+=2;
if(ans5.equals("False"))
    Total+=2;
try
{
    Statement stmt=connect.createStatement();
    String query="INSERT INTO st1("+"seat_no,name,marks"+")VALUES('"+seat_no+"','"+name+"','"+Total+"')";
    stmt.executeUpdate(query);
    stmt.close();
}

当我编译应用程序时,我不断收到这样的异常:

HTTP Status 500 - 

type Exception report
message: 
description The server encountered an internal error () that prevented it from fulfilling this request.
exception :
java.lang.NullPointerException
    s3.doPost(s3.java:52)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
note :The full stack trace of the root cause is available in the Apache Tomcat/6.0.13 logs

但我找不到任何可用于 MyEclipse Tomcat 6.0.13 的日志。谁能帮我克服这个例外?这是我的学术项目!提前致谢 !!

4

4 回答 4

5

查看文件 s3.java,第 52 行。

于 2011-03-18T11:25:38.743 回答
3

我的猜测是您正在检索的字段之一getParameter不存在所以它在null. 当您调用.equals()该字段时,您将获得 NPE。如果我们知道哪一行是 #52 会有所帮助。

作为第一步,我将重写所有检查,例如:

ans1.equals("True")

"true".equalsIgnoreCase(ans1)

甚至更好

Boolean.getBoolean(ans1) == true

然后,即使请求中未提供该字段,您也不会获得 NPE。

于 2011-03-18T11:35:20.890 回答
1

来自@Jan Zyka 的支持回答

尝试这个

if("True".equals(ans1))
    Total+=2;
if("False".equals(ans2))
    Total+=2;
if("True".equals(ans3))
    Total+=2;
if("False".equals(ans4))
    Total+=2;
if("False".equals(ans5))
    Total+=2;
try
{
   if(Total>0)// Just a condition.. !
   {
    Statement stmt=connect.createStatement();
    String query="INSERT INTO st1("+"seat_no,name,marks"+")VALUES('"+seat_no+"','"+name+"','"+Total+"')";
    stmt.executeUpdate(query);
    stmt.close();
  }
}
于 2011-03-18T12:29:38.130 回答
0

I think you might be ending with any parameter with NULL at file s3.java, line 52

Check what parameters are you getting there ?

于 2011-03-18T13:29:44.953 回答