我创建了一个login.jsp页面...在此页面提交按钮底部添加新用户链接。如果我点击该链接打开新的用户注册表单。我已经在oracle中创建表,如果我提供数据我想存储在数据库中,但它指示空指针异常.....来自newuser_db.java的第92行我的数据库连接编码在newuser_db.java中。请帮我......
错误:第92行是stmt1 = con.prepareStatement("insert into userdetails values(ka1.nextval,?,?,?,?,?,?,?,23,'as','14-nov-87')");
设计:
完整代码:
package com.sla;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class newuser_db
*/
public class newuser_db extends HttpServlet {
private static final long serialVersionUID = 1L;
PreparedStatement stmt=null;
Connection con =null;
ResultSet rs=null;
/**
* @see HttpServlet#HttpServlet()
*/
public newuser_db() {
super();
// TODO Auto-generated constructor stub
}
@Override
public void init() throws ServletException {
// TODO Auto-generated method stub
super.init();
try
{
Class.forName("sun.Jdbc.Odbc.JdbcOdbcDriver");
}
catch (ClassNotFoundException ex)
{
ex.printStackTrace();
}
try
{
con =DriverManager.getConnection("Jdbc:odbc:servletdb","system","balaji");
}
catch(SQLException ex)
{
ex.printStackTrace();
}
// TODO Auto-generated method stub
}
@Override
public void service(ServletRequest arg0, ServletResponse arg1)
throws ServletException, IOException {
// TODO Auto-generated method stub
super.service(arg0, arg1);
PrintWriter out=arg1.getWriter();
String s1=arg0.getParameter("USERID");
String s2=arg0.getParameter("FIRSTNAME");
String s3=arg0.getParameter("LASTNAME");
String s4=arg0.getParameter("EMAILID");
String s5=arg0.getParameter("ORGNAME");
String s6=arg0.getParameter("MOBILENO");
String s7=arg0.getParameter("PHONENO");
String s8=arg0.getParameter("PASSWORD");
out.println("inserted");
out.println(s1);
out.println("inserted1");
//String sql="insert into userdetails values(ka.nextval,"+s1+","+s2+","+s3+","+s4+","+s5+","+s6+","+s7+",56,'de',01-jan-98)";
PreparedStatement stmt1;
try {
stmt1 = con.prepareStatement("insert into userdetails values(ka1.nextval,?,?,?,?,?,?,?,23,'as','14-nov-87')");
stmt1.setString(1,s1);
stmt1.setString(2,s2);
stmt1.setString(3,s3);
stmt1.setString(4,s4);
stmt1.setString(5,s5);
stmt1.setString(6,s6);
stmt1.setString(7,s7);
stmt1.setString(8,s8);
//stmt1.executeUpdate();
out.println("inserted2");
stmt1.executeUpdate();
out.println("inserted3");
} catch (SQLException e1) {
// TODO Auto-generated catch block
out.println(e1);
}
}
@Override
public void destroy() {
// TODO Auto-generated method stub
super.destroy();
try
{
if(stmt!=null)
stmt.close();
stmt=null;
}
catch (SQLException ex)
{
ex.printStackTrace();
}
try
{
if(con!=null)
con.close();
con=null;
}
catch (SQLException ex)
{
ex.printStackTrace();
}
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
}
}
请帮助我任何人......我很困惑.......
答案 0 :(得分:4)
这看起来像是你跟随RoseIndia.net的可怕教程之一。我建议为JDBC教程阅读更好的网站。
您的代码可能会出现很多问题。我建议你从团队中有知识渊博的人那里获得帮助;一个互联网论坛只能帮助你。
PreparedStatement
,ResultSet
和Connection
被声明为servlet的类成员。这是糟糕的编码实践,因为这些成员现在将在多个请求之间共享,并且任何请求都能够更改这些成员的状态,从而导致其他请求的模糊和混乱行为。sun.Jdbc.Odbc.JdbcOdbcDriver
用于连接Oracle 10g Express版本实例。这对于JDBC驱动程序来说是一个糟糕的选择,因为它是一个类型1驱动程序,并且当您没有数据库的实际JDBC驱动程序时可以使用它。请改用Oracle 10g / 11g JDBC驱动程序。ClassNotFoundException
中捕获SQLException
和init
等异常,并在不中止执行的情况下打印其堆栈跟踪。在这种情况下,容器将忽略抛出的任何异常,因为您打印了它们的堆栈跟踪。因此servlet将被初始化,但考虑到异常的性质,它完全无法处理请求。service
,而不是为doGet
和doPost
提供方法正文。这又是一种糟糕的做法。不要覆盖service
,除非你有充分的理由(而且我很确定你没有)。说了这么多,你最有可能在NullPointerException
方法中获得service
的原因可能是因为init
方法的这一行引发了异常:< / p>
con =DriverManager.getConnection("Jdbc:odbc:servletdb","system","balaji");
由于您正在捕获此行抛出的任何异常,并且没有对其执行任何操作,因此您会发现con
变量在此类事件中将为null。稍后,当servlet处理请求并尝试创建PreparedStatement
实例时,它将失败,因为Connection
实例为null。
答案 1 :(得分:0)
如果在第92行遇到NullPointerException,则 con 似乎为空。您的代码是否已调用 init ?我注意到它没有从构造函数中调用。