Java 无法捕获servlet中的主键异常
我正在表中插入一些值,并在servlet中创建一个新表。 我编写了一段代码来捕获SQLException并重定向到带有错误消息的jsp页面。 当使用servlet在表中插入新值时,如果主键约束被违反,我的servlet不会捕获异常,并且会得到一个空白页 我的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;
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。谢谢你帮助我。