Struts-2-struts-hibernate
Struts 2とHibernateの統合
Hibernateは、オープンソースのGNU Lesser General Public License(LGPL)の下でライセンスされ、無料でダウンロードできる高性能のオブジェクト/リレーショナル永続性およびクエリサービスです。 この章では。 Struts 2とHibernateの統合を実現する方法を学習します。 Hibernateに慣れていない場合は、リンク:/hibernate/index [Hibernateチュートリアル]を確認してください。
データベースのセットアップ
このチュートリアルでは、「struts2_tutorial」MySQLデータベースを使用します。 ユーザー名「root」を使用し、パスワードは使用せずに、マシン上のこのデータベースに接続します。 まず、次のスクリプトを実行する必要があります。 このスクリプトは、*学生*という新しいテーブルを作成し、このテーブルにいくつかのレコードを作成します-
CREATE TABLE IF NOT EXISTS `student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`first_name` varchar(40) NOT NULL,
`last_name` varchar(40) NOT NULL,
`marks` int(11) NOT NULL,
PRIMARY KEY (`id`)
);
--
-- Dumping data for table `student`
--
INSERT INTO `student` (`id`, `first_name`, `last_name`, `marks`)
VALUES(1, 'George', 'Kane', 20);
INSERT INTO `student` (`id`, `first_name`, `last_name`, `marks`)
VALUES(2, 'Melissa', 'Michael', 91);
INSERT INTO `student` (`id`, `first_name`, `last_name`, `marks`)
VALUES(3, 'Jessica', 'Drake', 21);
休止状態の設定
次に、hibernateの構成ファイルであるhibernate.cfg.xmlを作成しましょう。
<?xml version = '1.0' encoding = 'utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name = "hibernate.connection.driver_class">c
om.mysql.jdbc.Driver
</property>
<property name = "hibernate.connection.url">
jdbc:mysql://www.finddevguides.com/struts_tutorial
</property>
<property name = "hibernate.connection.username">root</property>
<property name = "hibernate.connection.password"></property>
<property name = "hibernate.connection.pool_size">10</property>
<property name = "show_sql">true</property>
<property name = "dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name = "hibernate.hbm2ddl.auto">update</property>
<mapping class = "com.finddevguides.hibernate.Student"/>
</session-factory>
</hibernate-configuration>
hibernate構成ファイルを見ていきましょう。 まず、MySQLドライバーを使用していることを宣言しました。 次に、データベースに接続するためのjdbc URLを宣言しました。 次に、接続のユーザー名、パスワード、およびプールサイズを宣言しました。 また、「show_sql」をtrueに設定することで、ログファイルにSQLを表示することを示しました。 これらのプロパティの意味を理解するには、Hibernateチュートリアルをご覧ください。
最後に、この章で作成するマッピングクラスをcom.finddevguides.hibernate.Studentに設定します。
環境設定
次に、このプロジェクトには多くのjarが必要です。 添付されている必要なJARファイルの完全なリストのスクリーンショットです-
ほとんどのJARファイルは、Strutsディストリビューションの一部として取得できます。 glassfish、websphere、jbossなどのアプリケーションサーバーがインストールされている場合は、残りのjarファイルの大部分をappserverのlibフォルダーから取得できます。 そうでない場合は、ファイルを個別にダウンロードできます-
- Hibernate jarファイル-http://hibernate.org/[Hibernate.org]
- Struts hibernateプラグイン-https://code.google.com/p/full-hibernate-plugin-for-struts2/downloads/list[Struts hibernateプラグイン]
- JTAファイル-https://www.oracle.com/technetwork/java/javaee/jta/indexl[JTAファイル]
- Dom4jファイル-http://dom4j.sourceforge.net/[Dom4j]
- log4jファイル-https://logging.apache.org/log4j/1.2/[log4j]
残りのファイルは、Struts2ディストリビューションから取得できるはずです。
Hibernateクラス
hibernate統合に必要なJavaクラスを作成しましょう。 以下は Student.java の内容です-
package com.finddevguides.hibernate;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name = "student")
public class Student {
@Id
@GeneratedValue
private int id;
@Column(name = "last_name")
private String lastName;
@Column(name = "first_name")
private String firstName;
private int marks;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public int getMarks() {
return marks;
}
public void setMarks(int marks) {
this.marks = marks;
}
}
これは、Hibernate仕様に従って student テーブルを表すPOJOクラスです。 学生テーブルの列名に対応するプロパティid、firstName、lastNameがあります。 次に、次のように StudentDAO.java ファイルを作成します-
package com.finddevguides.hibernate;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.Transaction;
import com.googlecode.s2hibernate.struts2.plugin.\
annotations.SessionTarget;
import com.googlecode.s2hibernate.struts2.plugin.\
annotations.TransactionTarget;
public class StudentDAO {
@SessionTarget
Session session;
@TransactionTarget
Transaction transaction;
@SuppressWarnings("unchecked")
public List<Student> getStudents() {
List<Student> students = new ArrayList<Student>();
try {
students = session.createQuery("from Student").list();
} catch(Exception e) {
e.printStackTrace();
}
return students;
}
public void addStudent(Student student) {
session.save(student);
}
}
StudentDAOクラスは、Studentクラスのデータアクセスレイヤーです。 すべての学生をリストし、新しい学生レコードを保存するメソッドがあります。
アクションクラス
次のファイル AddStudentAction.java は、アクションクラスを定義します。 ここには、execute()とlistStudents()の2つのアクションメソッドがあります。 execute()メソッドは、新しい学生レコードを追加するために使用されます。 daoのsave()メソッドを使用してこれを実現します。
もう1つのメソッドlistStudents()は、学生をリストするために使用されます。 daoのlistメソッドを使用して、すべての学生のリストを取得します。
package com.finddevguides.struts2;
import java.util.ArrayList;
import java.util.List;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;
import com.finddevguides.hibernate.Student;
import com.finddevguides.hibernate.StudentDAO;
public class AddStudentAction extends ActionSupport implements ModelDriven<Student> {
Student student = new Student();
List<Student> students = new ArrayList<Student>();
StudentDAO dao = new StudentDAO();
@Override
public Student getModel() {
return student;
}
public String execute() {
dao.addStudent(student);
return "success";
}
public String listStudents() {
students = dao.getStudents();
return "success";
}
public Student getStudent() {
return student;
}
public void setStudent(Student student) {
this.student = student;
}
public List<Student> getStudents() {
return students;
}
public void setStudents(List<Student> students) {
this.students = students;
}
}
ModelDrivenインターフェイスを実装していることに気づくでしょう。 これは、アクションクラスが個別のプロパティ(firstName、lastNameなど)ではなく、具象モデルクラス(Studentなど)を処理する場合に使用されます。 ModelAwareインターフェイスでは、モデルを返すメソッドを実装する必要があります。 この場合、「学生」オブジェクトを返します。
ビューファイルを作成する
次の内容で student.jsp ビューファイルを作成しましょう-
<%@ page contentType = "text/html; charset = UTF-8"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<html>
<head>
<title>Hello World</title>
<s:head/>
</head>
<body>
<s:form action = "addStudent">
<s:textfield name = "firstName" label = "First Name"/>
<s:textfield name = "lastName" label = "Last Name"/>
<s:textfield name = "marks" label = "Marks"/>
<s:submit/>
<hr/>
<table>
<tr>
<td>First Name</td>
<td>Last Name</td>
<td>Marks</td>
</tr>
<s:iterator value = "students">
<tr>
<td><s:property value = "firstName"/></td>
<td><s:property value = "lastName"/></td>
<td><s:property value = "marks"/></td>
</tr>
</s:iterator>
</table>
</s:form>
</body>
</html>
student.jspは非常に簡単です。 上部のセクションには、「addStudent.action」に送信するフォームがあります。 firstName、lastName、marksを取ります。 addStudentアクションはModelAwareの「AddSudentAction」に関連付けられているため、firstName、lastName、およびマークが自動入力された値を持つ学生Beanが自動的に作成されます。
下部のセクションでは、学生リストを確認します(AddStudentAction.javaを参照)。 リストを反復処理し、名、姓、およびマークを表に表示します。
Struts構成
*struts.xml* を使用してまとめてみましょう-
<?xml version = "1.0" Encoding = "UTF-8"?>
<!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 = "myhibernate" extends = "hibernate-default">
<action name = "addStudent" method = "execute"
class = "com.finddevguides.struts2.AddStudentAction">
<result name = "success" type = "redirect">
listStudents
</result>
</action>
<action name = "listStudents" method = "listStudents"
class = "com.finddevguides.struts2.AddStudentAction">
<result name = "success">/students.jsp</result>
</action>
</package>
</struts>
ここで重要なことは、パッケージ「myhibernate」が「hibernate-default」と呼ばれるstruts2デフォルトパッケージを拡張することです。 次に、addStudentとlistStudentsの2つのアクションを宣言します。 addStudentはAddStudentActionクラスでexecute()を呼び出し、成功するとlistStudentsアクションメソッドを呼び出します。
listStudentアクションメソッドは、AddStudentActionクラスのlistStudents()を呼び出し、student.jspをビューとして使用します。
次に、プロジェクト名を右クリックし、[エクスポート]> [WARファイル] をクリックして、WARファイルを作成します。 次に、このWARをTomcatのwebappsディレクトリにデプロイします。 最後に、Tomcatサーバーを起動して、URL *http://localhost:8080/HelloWorldStruts2/student.jsp にアクセスしてみます。 これにより、次の画面が生成されます-
上部のセクションには、新しい学生レコードの値を入力するフォームがあり、下部のセクションにはデータベース内の学生がリストされています。 先に進み、新しい学生記録を追加して、送信を押します。 [送信]をクリックするたびに、画面が更新され、更新されたリストが表示されます。