Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/366.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 无法捕获servlet中的主键异常_Java_Exception_Servlets_Exception Handling_Java.util.logging - Fatal编程技术网

Java 无法捕获servlet中的主键异常

Java 无法捕获servlet中的主键异常,java,exception,servlets,exception-handling,java.util.logging,Java,Exception,Servlets,Exception Handling,Java.util.logging,我正在表中插入一些值,并在servlet中创建一个新表。 我编写了一段代码来捕获SQLException并重定向到带有错误消息的jsp页面。 当使用servlet在表中插入新值时,如果主键约束被违反,我的servlet不会捕获异常,并且会得到一个空白页 我的servlet代码:- package Servlets; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream;

我正在表中插入一些值,并在servlet中创建一个新表。 我编写了一段代码来捕获SQLException并重定向到带有错误消息的jsp页面。 当使用servlet在表中插入新值时,如果主键约束被违反,我的servlet不会捕获异常,并且会得到一个空白页

我的servlet代码:-

package Servlets;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;


/**
 *
 * @author TALPESH
 */

@MultipartConfig
public class Upload extends HttpServlet {
 private final static Logger LOGGER = 
            Logger.getLogger(Upload.class.getCanonicalName());

    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException{
        response.setContentType("text/html;charset=UTF-8");
    Connection con;
    Statement s; 
    final String path = "D:/6th sem/MP/OnlineExamination/web/app_data/questionbanks";
    final Part filePart = request.getPart("file");
    final String fileName = getFileName(filePart);
      String branch = request.getParameter("branch");
      String sem = request.getParameter("semester");
      String course = request.getParameter("course");
      String name = request.getParameter("name");


    OutputStream out = null;
    InputStream filecontent = null;
        PrintWriter writer = response.getWriter();
 try {
      Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
           con=DriverManager.getConnection("jdbc:odbc:online_testing");
           s=con.createStatement();
           String sql="insert into bank(branch,sem,course,bname) values('"+branch+"','"+sem+"','"+course+"','"+name+"')";
           s.executeUpdate(sql);
           String sql3="CREATE TABLE "+name+"(ID AUTOINCREMENT,question varchar(255),option1 varchar(255),option2 varchar(255),option3 varchar(255),option4 varchar(255),answer varchar(255)) ";
            s.executeUpdate(sql3);
            s.close();
            con.close();
             out = new FileOutputStream(new File(path + File.separator
                + fileName));
        filecontent = filePart.getInputStream();

        int read = 0;
        final byte[] bytes = new byte[1024];

        while ((read = filecontent.read(bytes)) != -1) {
            out.write(bytes, 0, read);
        }


         request.getSession().setAttribute("msg", "Your Question bank has been uploaded");
        response.sendRedirect("fhome.jsp");



    }
        catch (SQLException ex) {
            response.sendRedirect("fhome.jsp");
             request.getSession().setAttribute("msg", ex.getMessage().toString());

            Logger.getLogger(Upload.class.getName()).log(Level.SEVERE,"exception occurred", ex);
        }       
            catch (ClassNotFoundException ex) {
            Logger.getLogger(Upload.class.getName()).log(Level.SEVERE, null, ex);
        }        
          catch (FileNotFoundException fne) {
         request.getSession().setAttribute("msg", "You did not specify a file to upload.");
        response.sendRedirect("fhome.jsp");


        LOGGER.log(Level.SEVERE, "Problems during file upload. Error: {0}", 
                new Object[]{fne.getMessage()});
    } 
 finally {
        if (out != null) {
            out.close();
        }
        if (filecontent != null) {
            filecontent.close();
        }
        if (writer != null) {
            writer.close();
        }
    }

    }

  private String getFileName(final Part part) {
    final String partHeader = part.getHeader("content-disposition");
    LOGGER.log(Level.INFO, "Part Header = {0}", partHeader);
    for (String content : part.getHeader("content-disposition").split(";")) {
        if (content.trim().startsWith("filename")) {
            return content.substring(
                    content.indexOf('=') + 1).trim().replace("\"", "");
        }
    }
    return null;
}    // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">

    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

    }


    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

    }


    @Override
    public String getServletInfo() {
        return "Short description";
    }// </editor-fold>
}

在我看来,这是一个非常糟糕的主意,因为在Java 6中,该方法没有记录为接受null:

Logger.getLogger(Upload.class.getName()).log(Level.SEVERE, null, ex);
用类似的东西替换它

Logger.getLogger(Upload.class.getName()).log(Level.SEVERE, "exception occurred", ex);

然后检查您的日志输出-它应该被记录。

问题是您从未在其他方法中调用processRequest方法。processRequest方法不是Servlet API的一部分,因此您需要自己调用它。

1如果您处理用户输入,请使用preparedStatement 2为什么要在每个用户请求时创建一个新表?因为将在此Servlet中准备一个新测试。我将在下面的代码中填充此表。您有一些异常描述或引起的?如果有,请张贴。认真地说,你应该使用准备好的声明。这是一个典型的安全漏洞。我的日志是空的…我看不出出现问题的原因。仍然是相同的问题。它没有被记录。您是否检查了日志配置?你可以记录任何东西吗?我有一个类似的servlet,它可以成功记录sql异常。我已经检查过了。我不知道这个servlet有什么问题。可能我应该把我的整个servlet代码都放进去。看一看。我正在用完整的servlet代码编辑问题。谢谢如果没有记录或显示任何内容,你就不能确定它是一个sqlexception全部。当我删除主键约束时,代码运行良好。看到这一点,我感到震惊。到目前为止,我在netbeans中创建了许多servlet,它在get和post方法中自动调用process request。这是我项目中第一个没有调用的servlet。谢谢你帮助我。