1

JSPページは詳細ユーザーを入力し、strutsアクションに送信しstruts.xml、アクションをActionクラスOrderProcessingActionメソッドにマップし、実際のデータがDBテーブルフィールドにアクセスするDAOクラスのsaveOrUpdate()このメソッド呼び出しをマップしました。saveOrUpdateUser()

以下は成果物です。

  1. JSP ページ: Welcome.jsp
  2. ActionClass : OrderProcessingAction.java
  3. データ アクセス: UserDaoFactory.java オブジェクト
  4. struts.xml ファイル
/**
 * Welcome.Jsp : Here my JSP page code.
 */
<s:form method="post" name="myform" action="saveOrUpdate.action">

    <s:textfield label="Customer Name" name="username" size="30"/>

    <s:password label="Customer Password" name="password" size="30"/>

    <s:textfield label="Contact No" name="contact" size="30"/>

    <s:textfield label="Email" name="email" size="30"/>

    <s:textfield label="City" name="city" size="30"/>


    <s:submit label="Submit" />
    <s:reset label="Clear"/>

</s:form>

こちらstruts.xmlのファイル。

<action name="saveOrUpdate" 
        class="com.view.OrderProcessingAction" 
        method="saveOrUpdate">
 <result name="success">/Welcome.jsp</result>
</action> 

以下は、DAO クラス メソッドの呼び出しを取得している OrderProcessingAction (ActionClass) です。

private String username;
private String password;
private int contact;
private String email;
private String city;

//Pojo class OrderPorcessing reference initiated
OrderProcessing user = new OrderProcessing();   

public String getUsername() {
    return username;
}
public void setUsername(String username) {
    this.username = username;
}
public String getPassword() {
    return password;
}
public void setPassword(String password) {
    this.password = password;
}   
public int getContact() {
    return contact;
}
public void setContact(int contact) {
    this.contact = contact;
}
public String getEmail() {
    return email;
}
public void setEmail(String email) {
    this.email = email;
}
public String getCity() {
    return city;
}
public void setCity(String city) {
    this.city = city;
}

  /**
  * To save or update user. 
   * @return String
  */
   public String saveOrUpdate(){

    userDaoFactory.saveOrUpdateUser(user);
    System.out.println("User Name: " +user.getUsername());
    return SUCCESS;
  }

DAO クラスの saveOrUpdate メソッドの下。

     /**
     * Used to save or update a user by saveOrUpdate().
     * @return void
     */
      public void saveOrUpdateUser(User user) {
    try {
        session = HibernateUtil.getSessionFactory().openSession();
        tx = session.getTransaction();

        session.saveOrUpdate(user);

        tx.commit();
        session.close();

    } catch (Exception e) {

        e.printStackTrace();
    }
}
4

2 に答える 2

0

コードでは、DAO を一般的なトランザクションに置き換える必要があります

典型的なトランザクションでは、次のイディオムを使用する必要があります。

 Session sess = factory.openSession();
 Transaction tx;
 try {
     tx = sess.beginTransaction();
     //do some work
     ...
     tx.commit();
 }
 catch (Exception e) {
     if (tx!=null) tx.rollback();
     throw e;
 }
 finally {
     sess.close();
 }
于 2013-05-06T09:10:12.973 に答える
0

これを行う代わりに

System.out.println("User Name: " +user.getUsername());

これを行う

System.out.println("User Name: " +getUsername());
于 2013-05-06T08:09:34.920 に答える