RegAction.java
private static final String FORWARD_succ = "succ";
Connection con=null;
public Connection getcon()
{
try
{
Class.forName("com.mysql.jdbc.Driver");
con=DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql","root","root");
}catch(SQLException e)
{}
catch(ClassNotFoundException c)
{
}
return con;
}
public void closeConnection()
{
try
{
con.close();
}catch(SQLException e)
{}
}
public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws ServletException
{
RegForm1 r=(RegForm1)form;
Connection con=getcon();
String v1=r.getFname();
String v2=r.getLname();
String v3=r.getUid();
String v4=r.getDob();
String v5=r.getPwd();
String v6=r.getCpwd();
String v7=r.getCity();
String v8=r.getSt();
String v9=r.getZc();
System.out.println(v1);
System.out.println(v2);
System.out.println(v3);
System.out.println(v4);
System.out.println(v5);
System.out.println(v6);
System.out.println(v7);
System.out.println(v8);
System.out.println(v9);
try
{
PrintWriter pw=response.getWriter();
Statement ps=con.createStatement();
int k=ps.executeUpdate("insert into reg values(v1,v2,v3,v4,v5,v6,v7,v8,v9)");
if(k==1)
pw.println("susccessfully stored");
con.commit();
}catch(SQLException s)
{
}
catch(IOException s)
{
}
return mapping.findForward("succ");
config.xml中
<form-bean name="regform" type="RegForm1"/>
</form-beans>
<global-exceptions/>
<global-forwards/>
<action-mappings>
<action name="regform" path="/reg" type="RegAction" validate="true input="/Register.jsp">
<forward name="succ" path="/success.jsp"/>
我想在mysql数据库中存储以下字段值。但我得到以下例外原因?
新用户详情 名字*: 姓氏*:
userid *:
Dob *:
密码*:
确认密码*
城市*:
州*:
Zipcode *:
按钮
HTTP状态500 -
type Exception report
message
description The server encountered an internal error () that prevented it from fulfilling this request.
exception
javax.servlet.ServletException
org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:286)
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462)
javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
root cause
java.lang.NullPointerException
RegAction.execute(RegAction.java:75)
org.apache.struts.chain.commands.servlet.ExecuteAction.execute(ExecuteAction.java:58)
org.apache.struts.chain.commands.AbstractExecuteAction.execute(AbstractExecuteAction.java:67)
org.apache.struts.chain.commands.ActionCommandBase.execute(ActionCommandBase.java:51)
org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
org.apache.commons.chain.generic.LookupCommand.execute(LookupCommand.java:304)
org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:283)
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462)
javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
note The full stack trace of the root cause is available in the Apache Tomcat/5.5.29 logs.
Apache Tomcat / 5.5.29
答案 0 :(得分:1)
SIVA ..
int k=ps.executeUpdate("insert into reg values(v1,v2,v3,v4,v5,v6,v7,v8,v9)");
上述语句V1,V2,v3...
中的被视为字符串值,而不是使用PrepareStatement
。
否则重写像这样的代码
int k=ps.executeUpdate("insert into reg values('"+v1+"','"+v2+"','"+ . . );
如果列表中有任何数值(v1,v2,v3 ..),则无需输入''
代码。
希望你能得到这个......
答案 1 :(得分:0)
您的代码实际上很难阅读。我猜这一行:Statement ps=con.createStatement();
导致NPE
。考虑到您忽略了getCon
方法中的异常,很难说。你绝对不应该忽略那些类型的例外。您应该记录它们并查看确切的异常。使用一些日志框架来做到这一点,或者只是简单地打印堆栈跟踪以将其视为自己。
catch(SQLException e) {
//log the exception
}
catch(ClassNotFoundException c) {
//log the exception
}
我认为您getCon
方法中的关联返回为null
。您应该检查数据库连接是否有任何问题。