Apache Tapestry - Hibernasi
Pada bab ini, kita akan membahas tentang integrasi BeanEditForm dan Grid componentdengan Hibernate. Hibernasi diintegrasikan ke permadani melalui modul hibernasi. Untuk mengaktifkan modul hibernate, tambahkan dependensi tapestry-hibernate dan secara opsionalhsqldb dalam pom.xmlmengajukan. Sekarang, konfigurasikan hibernasi melalui filehibernate.cfg.xml file ditempatkan di root folder sumber daya.
pom.xml (sebagian)
<dependency>
<groupId>org.apache.tapestry</groupId>
<artifactId>tapestry-hibernate</artifactId>
<version>${tapestry-release-version}</version>
</dependency>
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<version>2.3.2</version>
</dependency>
Hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name = "hibernate.connection.driver_class">
org.hsqldb.jdbcDriver
</property>
<property name = "hibernate.connection.url">
jdbc:hsqldb:./target/work/sampleapp;shutdown = true
</property>
<property name = "hibernate.dialect">
org.hibernate.dialect.HSQLDialect
</property>
<property name = "hibernate.connection.username">sa</property>
<property name = "hibernate.connection.password"></property>
<property name = "hbm2ddl.auto">update</property>
<property name = "hibernate.show_sql">true</property>
<property name = "hibernate.format_sql">true</property>
</session-factory>
</hibernate-configuration>
Mari kita lihat cara membuat file employee add page menggunakan komponen BeanEditForm dan employee list pagemenggunakan komponen Grid. Lapisan persistensi ditangani oleh modul Hibernate.
Buat kelas karyawan dan hiasi dengan anotasi @Entity. Kemudian, tambahkan anotasi validasi untuk bidang yang relevan dan hibernasi anotasi terkait @Id dan @GeneratedValue untuk bidang id. Juga, buat gender sebagai tipe enum.
Employee.java
package com.example.MyFirstApplication.entities;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import org.apache.tapestry5.beaneditor.NonVisual;
import org.apache.tapestry5.beaneditor.Validate;
@Entity
public class Employee {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@NonVisual
public Long id;
@Validate("required")
public String firstName;
@Validate("required")
public String lastName;
@Validate("required")
public String userName;
@Validate("required")
public String password;
@Validate("required")
public String email;
public String phone;
@Validate("required")
public String Street;
@Validate("required")
public String city;
@Validate("required")
public String state;
@Validate("required,regexp=^\\d{5}(-\\d{4})?$")
public String zip;
}
Gender.java (enum)
package com.example.MyFirstApplication.data;
public enum Gender {
Male, Female
}
Buat halaman daftar karyawan, ListEmployee.java di folder baru karyawan di bawah halaman dan file template yang sesuai ListEmployee.tml di /src/main/resources/pages/employeemap. Permadani menyediakan URL singkat untuk sub folder dengan menghapus data berulang.
Misalnya, halaman ListEmployee dapat diakses dengan URL normal - (/ employee / listemployee) dan dengan URL singkat - (/ employee / list).
Masukkan sesi Hibernate ke dalam halaman daftar menggunakan anotasi @Inject. Tentukan propertigetEmployeesdi halaman daftar dan mengisinya dengan karyawan menggunakan objek sesi yang dimasukkan. Lengkapi kode untuk kelas karyawan seperti yang ditunjukkan di bawah ini.
ListEmployee.java
package com.example.MyFirstApplication.pages.employee;
import java.util.List;
import org.apache.tapestry5.annotations.Import;
import org.apache.tapestry5.ioc.annotations.Inject;
import org.hibernate.Session;
import com.example.MyFirstApplication.entities.Employee;
import org.apache.tapestry5.annotations.Import;
@Import(stylesheet="context:mybootstrap/css/bootstrap.css")
public class ListEmployee {
@Inject
private Session session;
public List<Employee> getEmployees() {
return session.createCriteria(Employee.class).list();
}
}
Buat file template untuk kelas ListEmployee. Template akan memiliki dua komponen utama, yaitu -
PageLink - Buat halaman tautan karyawan.
Grid- Digunakan untuk membuat detail karyawan. Komponen grid memiliki atribut sumber untuk memasukkan daftar karyawan dan menyertakan atribut untuk menyertakan bidang yang akan dirender.
ListEmployee.tml (daftar semua karyawan)
<html t:type = "simplelayout" title = "List Employee"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd">
<h1>Employees</h1>
<ul>
<li><t:pagelink page = "employee/create">Create new employee</t:pagelink></li>
</ul>
<t:grid source = "employees"
include = "userName,firstName,lastName,gender,dateOfBirth,phone,city,state"/>
</html>
Buat file template pembuatan karyawan dan sertakan komponen BeanEditForm. Komponen memiliki atribut berikut -
object - Termasuk sumber.
reorder - Mendefinisikan urutan bidang yang akan dirender.
submitlabel - Pesan dari tombol pengiriman formulir
Pengodean lengkapnya adalah sebagai berikut -
<html t:type = "simplelayout" title = "Create New Address"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd">
<t:beaneditform
object = "employee"
submitlabel = "message:submit-label"
reorder = "userName,password,firstName,lastName,
dateOfBirth,gender,email,phone,s treet,city,state,zip" />
</html>
Buat kelas pembuatan karyawan dan sertakan sesi, properti karyawan, halaman daftar (tautan navigasi) dan tentukan acara OnSuccess (tempat untuk memperbarui data) komponen. Data sesi disimpan ke dalam database menggunakan sesi hibernasi.
Pengodean lengkapnya adalah sebagai berikut -
package com.example.MyFirstApplication.pages.employee;
import com.example.MyFirstApplication.entities.Employee;
import com.example.MyFirstApplication.pages.employee.ListEmployee;
import org.apache.tapestry5.annotations.InjectPage;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.hibernate.annotations.CommitAfter;
import org.apache.tapestry5.ioc.annotations.Inject;
import org.hibernate.Session;
public class CreateEmployee {
@Property
private Employee employee;
@Inject
private Session session;
@InjectPage
private ListEmployee listPage;
@CommitAfter
Object onSuccess() {
session.persist(employee);
return listPage;
}
}
Tambahkan CreateEmployee.propertiesfile dan sertakan pesan yang akan digunakan dalam validasi formulir. Kode lengkapnya adalah sebagai berikut -
zip-regexp=^\\d{5}(-\\d{4})?$
zip-regexp-message = Zip Codes are five or nine digits. Example: 02134 or 901251655.
submit-label = Create Employee
Tangkapan layar dari halaman pembuatan karyawan dan halaman daftar ditunjukkan di bawah ini -