簡體   English   中英

使用struts2將表單數據保存在數據庫中

[英]saving form data in the database using struts2

當我們單擊保存按鈕時,它必須將表單數據保存在數據庫中,但是什么也沒做。 下面是代碼

BodyDaywise.jsp

<%@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>

動作類:BodyDaywiseAction.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 !");
     }
}

}

DaywiseDBO.java

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;  
}  

} 

struts.xml

<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.devMode" value="true" />
<package name="default" extends="struts-default, tiles-default">
    <result-types>
        <result-type name="tiles"
            class="org.apache.struts2.views.tiles.TilesResult" />
    </result-types>
    <action name="loginaction" class="com.timesheet.action.LoginAction" method="execute">
        <result name="input" >/Login.jsp</result>
        <result name="success" type="tiles">/bodydaywise.tiles</result>
        <result name="error" type="tiles">/error.jsp</result>
    </action>
    <action name="daywise" class="com.timesheet.action.BodyDaywiseAction">
        <result name="success" type="tiles">/bodydaywisesuccess.tiles</result>
        <result name="error" type="tiles">/error.jsp</result>
    </action>
    </package>
  </struts>

如果我缺少什么,請告訴我。

您在操作類中使用了錯誤的日期/時間類型。 Struts2沒有用於java.sql.*類型的內置轉換器。 如果使用java.util.Date則日期/時間值應轉換為日期。 此類型的對象可以包含日期和時間值。

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

相應地更改獲取器和設置器以返回所需的內容。 您還可以將日期對象設置為“ Calendar並進行一些計算,然后可以從日歷中創建一個“ Timestamp對象。 例如

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

在將用戶添加到數據庫之前,將當前日期和時間設置為用戶對象。

使用PreparedStatement的示例: JDBC PreparedStatement示例–插入一條記錄

還有一個示例, 保存Date日期部分: 在PreparedStatement中插入日期值 (不要使用它,因為它不會保存Date的時間部分)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM