使用struts2在数据库中保存表单数据

时间:2015-10-05 09:03:59

标签: java jsp jdbc struts2 struts-tags

当我们点击保存按钮时,它必须将表单数据保存在数据库中,但它什么都不做。 以下是代码

BodyDaywise.jsp

buttonActions

动作类:BodyDaywiseAction.java

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles" %>
<%@ taglib prefix="s" uri="/struts-tags" %>    
<%@ taglib prefix="sx" uri="/struts-dojo-tags" %>

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Day Wise</title>
</head>
<body align="center">
    <h1 align="center">Day Wise Form</h1>
        <html:form action="daywise" class="BodyDaywiseAction" method="POST" >

            LoginDate: <input type="date" name="LoginDate" displayformat="yyyy-mm-dd" label="Login Date(yyyy-mm-dd)"/><br><br>
            LoginTime:<input id="start" type="time"  name="LoginTime"/><br><br>
            LogoutTime:<input id="end" type="time"  name="LogoutTime"/><br><br>
            Task:<input type="textarea" name="Task" label="Task" cols="20" rows="5"/><br><br>

            <input type="submit" value="save" name="Save" onClick=""/>
            <button type="submit" value="Clear" name="clear">Clear</button>
            <input type="button" value="cancel" onClick="history.back();"/>
            </html:form>
</body>
</html>

DaywiseDBO.java

package com.timesheet.action;
import com.opensymphony.xwork2.ActionSupport;
import com.timesheet.db.DaywiseDBO;
import java.sql.Date;
import java.sql.Time;
public class BodyDaywiseAction extends ActionSupport {
public BodyDaywiseAction()
{
}

private Date LoginDate;
private Time LoginTime;
private Time LogoutTime;
private String Task;


public Date getLoginDate() {
    return LoginDate;
}

public void setLoginDate(Date LoginDate) {
    this.LoginDate = LoginDate;
}

public Time getLoginTime() {
    return LoginTime;
}

public void setLoginTime(Time LoginTime) {
    this.LoginTime = LoginTime;
}

public Time getLogoutTime() {
    return LogoutTime;
}

public void setLogoutTime(Time LogoutTime) {
    this.LogoutTime = LogoutTime;
}

public String getTask() {
    return Task;
}

public void setTask(String Task) {
    this.Task = Task;
}

    private static final long serialVersionUID = 1L;



 @Override
public String execute() throws Exception {

     int i=DaywiseDBO.save(this);  
    if(i>0){  
    return "success";  
    }  
    return "error";  
}

@Override
public void validate() {
     if("".equals(getTask())){  
        addFieldError("Task", "Task must be filled !");
     }
}

}

struts.xml中

package com.timesheet.db;
import com.timesheet.action.BodyDaywiseAction;
import com.timesheet.dbutil.DBUtil;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class DaywiseDBO {  

public static int save(BodyDaywiseAction BDA) throws Exception{  
int status=0;  
Connection conn = null;
ResultSet rs = null;
PreparedStatement ps = null;
DBUtil util = null;

try{  
util = new DBUtil();
conn = util.getConnection();
ps = conn.prepareStatement("insert into logintable values(?,?,?,?)");  
ps.setDate(1,BDA.getLoginDate());  
ps.setTime(2,BDA.getLoginTime());  
ps.setTime(3,BDA.getLogoutTime());  
ps.setString(4,BDA.getTask());  

status=ps.executeUpdate();  

}catch(Exception e){
e.printStackTrace();}  
return status;  
}  

} 

如果我遗失了某些内容,请告诉我。

1 个答案:

答案 0 :(得分:1)

您在操作类中使用了错误的日期/时间类型。 Struts2没有java.sql.*类型的内置转换器。如果您使用java.util.Date,则日期/时间值应转换为日期。此类型的对象可以包含日期和时间值。

import java.util.Date;
import java.sql.Time;

相应地更改getter和setter以返回所需的内容。您还可以将日期对象设置为Calendar并进行一些计算,之后您可以从日历中创建Timestamp对象。例如

user.setCreateDate(new Timestamp(Calendar.getInstance().getTimeInMillis()));

设置当前的日期&amp;在将用户添加到数据库之前,将时间添加到用户对象。

使用PreparedStatement的示例:JDBC PreparedStatement example – Insert a record

还有一个示例可以保存Date的{​​em>仅日期部分:Insert date value in PreparedStatement。 (不要使用它,因为它不会保存Date的时间部分。)