Struts2从表单中获取数据到一个单独的类

时间:2016-06-27 17:48:44

标签: java jsp struts2 struts ognl

这将是一个奇怪的问题,我会尽力解释它,但请耐心等待。

我有一个.jsp页面,其中包含一个用于输入信息的表单,一个用于处理struts操作的SubmitAction.java页面,以及一个Request.java页面,它实际上只是我所有数据的容器(它&# 39;为了这个问题的目的被剥离了。实际上它包含更多的数据)。

我的主要问题是我无法获取Request对象以了解输入NewForm.jsp的任何数据。例如,在constructInsertStatement()函数内部进行调试时,myTextBox的值始终为null。

我会发布我所拥有的内容,希望有人可以告诉我我失踪的内容。

NewForm.jsp

<html>
<head>
<sx:head />

</head>
<body>

    <s:form action="submitNew" method="post" namespace="/">
        <s:textfield label="Text Box" name="myTextBox" 
        <s:submit label="Submit" name="submit_btn" align="center" />
    </s:form>
</body>
</html>  

提交Action.java

    public class SubmitAction extends ActionSupport {

    private Request request = new Request();

    public void executeInsert() throws SQLException{
        Connection conn = null;
        PreparedStatement ps = null;       

        try {    
            ps = request.constructInsertStatement();

            // execute the INSERT Statement
            ps.executeUpdate();
        } catch (SQLException e) {

            System.out.println(e.getMessage());

        } catch (Exception e) {

            System.out.println(e.getMessage());

        }finally {

            if (ps != null) {
                ps.close();
            }

            if (conn != null) {
                conn.close();
            }
        }
    }
}

Request.java

public class Request {
    private String myTextBox;

    public PreparedStatement constructInsertStatement() throws SQLException{
        PreparedStatement ps = null;
        Connection conn = null;  

        String URL = "myURL";

        try {
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        conn = DriverManager.getConnection(URL, "defaultUser", "defaultPassword");

        String sql = "INSERT INTO `myTable` (SomeText)"; 
        sql += "VALUES";
        sql+="(?)";

        ps = conn.prepareStatement(sql);

        try{
            ps.setString(1, myTextBox);

        } catch (SQLException e) {

            System.out.println(e.getMessage());

        } catch (Exception e) {

            System.out.println(e.getMessage());

        }

        return ps;
    }

    public String getmyTextBox() {
        return myTextBox;
    }

    public void setmyTextBox(String myTextBox) {
        this.myTextBox = myTextBox;
    }

Struts.xml操作

<struts> 
    <package name="default" extends="struts-default" namespace="/">        
        <action name="submitNew"
            class="my.package.path.SubmitAction" method="executeInsert">
            <result name="success">NewForm.jsp</result>
        </action>
    </package>
</struts>

1 个答案:

答案 0 :(得分:1)

要获得Request个对象,您应该拥有一个getter

public Request getMyRequest() { return request; }

要为此对象设置值,您需要有效的getter和setter

public String getMyTextBox() {
    return myTextBox;
}

public void setMyTextBox(String myTextBox) {
    this.myTextBox = myTextBox;
}

如果您想了解有关OGNL如何访问bean属性的更多信息,请参阅Struts2 passing variables case answer。

要将此对象绑定到文本字段,您应该在name属性中使用该属性的路径。

<s:textfield label="Text Box" name="myRequest.myTextBox" />
相关问题