Tapisserie Apache - Hibernation

Dans ce chapitre, nous discuterons de l'intégration de BeanEditForm et Grid componentavec Hibernate. Hibernate est intégré à la tapisserie via le module Hibernate. Pour activer le module Hibernate, ajoutez une dépendance tapestry-hibernate et éventuellementhsqldb dans le pom.xmlfichier. Maintenant, configurez la mise en veille prolongée via lehibernate.cfg.xml fichier placé à la racine du dossier de ressources.

pom.xml (partiel)

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

Voyons comment créer le employee add page en utilisant le composant BeanEditForm et le employee list pageen utilisant le composant Grid. La couche de persistance est gérée par le module Hibernate.

Créez une classe d'employés et décorez-la avec l'annotation @Entity. Ensuite, ajoutez une annotation de validation pour les champs pertinents et hibernez l'annotation associée @Id et @GeneratedValue pour le champ id. Créez également le genre comme type d'énumération.

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 
}

Créer la page de la liste des employés, ListEmployee.java dans le nouveau dossier employé sous les pages et le fichier modèle correspondant ListEmployee.tml à /src/main/resources/pages/employeedossier. Tapestry fournit une URL courte pour les sous-dossiers en supprimant les données répétées.

Par exemple, la page ListEmployee est accessible par une URL normale - (/ employee / listemployee) et par l'URL courte - (/ employee / list).

Injectez la session Hibernate dans la page de liste à l'aide de l'annotation @Inject. Définir une propriétégetEmployeesdans la page de liste et remplissez-la avec des employés à l'aide d'un objet de session injecté. Complétez le code de la classe d'employés comme indiqué ci-dessous.

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

Créez le fichier modèle pour la classe ListEmployee. Le modèle aura deux composants principaux, qui sont -

  • PageLink - Créer une page de lien pour les employés.

  • Grid- Utilisé pour rendre les détails de l'employé. Le composant de grille a des attributs sources pour injecter la liste des employés et inclure des attributs pour inclure les champs à rendre.

ListEmployee.tml (liste tous les employés)

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

Créez un fichier de modèle de création d'employé et incluez le composant BeanEditForm. Le composant a les attributs suivants -

  • object - Comprend la source.

  • reorder - Définit l'ordre des champs à rendre.

  • submitlabel - Le message du bouton de soumission de formulaire

Le codage complet est le suivant -

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

Créez une classe de création d'employé et incluez la session, la propriété de l'employé, la page de liste (lien de navigation) et définissez l'événement OnSuccess (endroit pour mettre à jour les données) du composant. Les données de session sont conservées dans la base de données à l'aide de la session de mise en veille prolongée.

Le codage complet est le suivant -

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

Ajouter le CreateEmployee.propertiesfichier et inclure le message à utiliser dans les validations de formulaire. Le code complet est le suivant -

zip-regexp=^\\d{5}(-\\d{4})?$ 
zip-regexp-message = Zip Codes are five or nine digits. Example: 02134 or 901251655. 
submit-label = Create Employee

La capture d'écran de la page de création des employés et de la page de liste est présentée ci-dessous