1

我正在研究 struts2 应用程序,我必须上传文件并将其保存到数据库中。但每次显示NullPointerException我的代码都在这里

堆栈跟踪是-

java.lang.NullPointerException
    dao.Clientdao.registration(Clientdao.java:31)
    action.client.Clientaction.execute(Clientaction.java:18)
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    java.lang.reflect.Method.invoke(Unknown Source)
    com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:452)
    com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:291)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:254)
    com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:176)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:263)
    org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:68)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:207)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:314)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:176)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:187)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
    org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:485)
    org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)

模型类是

import java.io.File;
public class Clientmodel {
private String Aggrement;
private String  date;
private String rate;
private String maturitydate;
private String detail;
private String taxno;
private File imagefile;
public File getImagefile() {
    return imagefile;
}

public void setImagefile(File imagefile) {
    this.imagefile = imagefile;
}

public String getRate() {
    return rate;
}

public void setRate(String rate) {
    this.rate = rate;
}

public String getDetail() {
    return detail;
}

public void setDetail(String detail) {
    this.detail = detail;
}

public String getTaxno() {
    return taxno;
}

public void setTaxno(String taxno) {
    this.taxno = taxno;
}

public String getAggrement() {
    return Aggrement;
}

public void setAggrement(String aggrement) {
    Aggrement = aggrement;
}



public String getMaturitydate() {
    return maturitydate;
}

public void setMaturitydate(String maturitydate) {
    this.maturitydate = maturitydate;
}

public String getDate() {
    return date;
}

public void setDate(String date) {
    this.date = date;
}

}

struts.xml

  <?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
       <constant name="struts.enable.DynamicMethodInvocation" value="true"/>
             <constant name="struts.devmode" value="true"/>
             <package name="loginmodel" extends ="struts-default">

        <action name="clientlogin"  class="action.client.Clientaction" >
           <interceptor-ref name="exception"/>
            <interceptor-ref name="i18n"/>
            <interceptor-ref name="fileUpload">
            <param name="allowedTypes">text/plain</param>
            <param name="maximumSize">10240</param>
        </interceptor-ref> 
            <interceptor-ref name="params">
                <param name="excludeParams">dojo\..*,^struts\..*</param>
            </interceptor-ref>
            <interceptor-ref name="validation">
                <param name="excludeMethods">input,back,cancel,browse</param>
            </interceptor-ref>
            <interceptor-ref name="workflow">
                <param name="excludeMethods">input,back,cancel,browse</param>
            </interceptor-ref>

            <result name="input">/Registration/clientregistration.jsp </result>
           <result name ="success">/Registration/success.jsp  </result>

          </action>

         </package>
</struts>

客户端注册.jsp

<%@ page language ="java" contentType ="text/html; charset=ISO-8859-1" pageEncoding ="ISO-8859-1"%>
<%@ taglib uri ="/struts-tags" prefix="s"%>
<%@ taglib uri ="/struts-dojo-tags" prefix="sx" %>
<%@ taglib prefix="sj" uri="/struts-jquery-tags"%>
<html>
<head>
<sj:head jqueryui="true" jquerytheme="redmond" />
<style>
   div.ui-datepicker {
      font-size: 82.5%;
       }
</style>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>CLIENT</title>
<link rel="stylesheet" type="text/css" href="css/emp.css">
</head>
<body >

<div id ="did" align="center"> <h1 style="color: red">  CLIENT REGISTRATION FORM</h1>
  <s:form action ="clientlogin" method="post" enctype="multipart/form-data">

<s:select  name="Aggrement" label ="Type of Aggrement" list ="{'ORAL', 'written'}  "/>
<sj:datepicker  name="date" label="Aggrement DATE" changeMonth="true" changeYear="true"/>

 <s:select name ="rate" list="{'1','2','3'}" label ="Aggrement rate"/>
<s:textarea  name ="detail" label ="Aggrement Detail"></s:textarea>
 <s:textfield name ="taxno" label="Tax No "></s:textfield>
 <s:file name ="imagefile" label ="Upload Document"  />
<tr><td>&nbsp;</td></tr>
        <tr>
    <td>&nbsp;</td>

 <s:submit align="center"></s:submit>
</s:form>
   </div>
  </body>
</html>

客户 dao 是

package dao;

import java.sql.Blob;
import java.sql.SQLException;
import model.Clientmodel;
import com.mysql.jdbc.PreparedStatement;
import com.mysql.jdbc.ResultSet;

public class Clientdao {

java.sql.Connection connection =null;   
PreparedStatement pst = null;   
ResultSet rs =null;

private java.sql.Connection getConnection() throws SQLException{
    java.sql.Connection conn;
conn = Connectionfactory.getInstance().getConntection();    
return conn;

}

public int registration(Clientmodel model){

    int i= 0;
   try{
      String str  = "insert into " + "clientdata(Aggrement,aggrementDate,rate,maturitydate,detail,taxno,image)"+
                     "values(?,?,?,?,?,?)";

       connection =getConnection();   

   pst =(PreparedStatement) connection.prepareStatement(str);
     pst.setString(1, model.getAggrement());
     pst.setString(2, model.getDate());
     pst.setString(3, model.getRate());
     pst.setString(4, model.getMaturitydate());
     pst.setString(5, model.getDetail());
     pst.setString(6, model.getTaxno());
     pst.setBlob(7,(Blob) model.getImagefile());    

     i = pst.executeUpdate();
     System.out.println("Result " +i);
   }
  catch (SQLException se){
    se.printStackTrace();  
   }
   return i;

}
}
4

1 回答 1

1

实现ModelDriven接口并将覆盖方法的对象返回给您的 Action 类中的模型类。

于 2013-04-25T06:55:43.907 回答