JSF - Guia Rápido

O que é JSF?

JavaServer Faces(JSF) é uma estrutura da web MVC que simplifica a construção de interfaces de usuário (UI) para aplicativos baseados em servidor usando componentes de UI reutilizáveis ​​em uma página. JSF fornece um recurso para conectar widgets de UI com fontes de dados e manipuladores de eventos do lado do servidor. A especificação JSF define um conjunto de componentes de UI padrão e fornece uma Interface de Programação de Aplicativo (API) para desenvolver componentes. O JSF permite a reutilização e extensão dos componentes de UI padrão existentes.

Benefícios

O JSF reduz o esforço na criação e manutenção de aplicativos, que serão executados em um servidor de aplicativos Java e renderizarão a IU do aplicativo em um cliente de destino. JSF facilita o desenvolvimento de aplicativos da Web por -

  • Fornecimento de componentes de IU reutilizáveis
  • Facilitando a transferência de dados entre os componentes da IU
  • Gerenciando o estado da IU em várias solicitações de servidor
  • Habilitando a implementação de componentes personalizados
  • Conectando evento do lado do cliente ao código do aplicativo do lado do servidor

Modelo de componente de interface do usuário JSF

O JSF fornece aos desenvolvedores a capacidade de criar aplicativos da Web a partir de coleções de componentes de IU que podem ser renderizados de maneiras diferentes para vários tipos de cliente (por exemplo - navegador HTML, sem fio ou dispositivo WAP).

JSF fornece -

  • Biblioteca central

  • Um conjunto de componentes básicos da IU - elementos de entrada HTML padrão

  • Extensão dos componentes de UI básicos para criar bibliotecas de componentes de UI adicionais ou para estender os componentes existentes

  • Vários recursos de renderização que permitem que os componentes da IU do JSF sejam renderizados de maneira diferente, dependendo dos tipos de cliente

Este capítulo irá guiá-lo sobre como preparar um ambiente de desenvolvimento para iniciar seu trabalho com o JSF Framework. Você aprenderá como configurar JDK, Eclipse, Maven e Tomcat em sua máquina antes de configurar o JSF Framework.

Requisitos do sistema

O JSF requer JDK 1.5 ou superior, portanto, o primeiro requisito é ter o JDK instalado em sua máquina.

JDK 1,5 ou acima
Memory Sem requisitos mínimos
Disk Space Sem requisitos mínimos
Operating System Sem requisitos mínimos

Configuração de ambiente para desenvolvimento de aplicativos JSF

Siga as etapas fornecidas para configurar seu ambiente para iniciar o desenvolvimento de aplicativos JSF.

Etapa 1: verifique a instalação do Java em sua máquina

Abra o console e execute o seguinte Java comando.

SO Tarefa Comando
janelas Abrir console de comando c: \> versão java
Linux Abra o terminal de comando $ java -version
Mac Terminal aberto máquina: ~ joseph $ java -version

Vamos verificar a saída de todos os sistemas operacionais -

SO Saída Gerada
janelas

versão java "1.6.0_21"

Java (TM) SE Runtime Environment (build 1.6.0_21-b07)

Cliente VM Java HotSpot (TM) (versão 17.0-b17, modo misto, compartilhamento)

Linux

versão java "1.6.0_21"

Java (TM) SE Runtime Environment (build 1.6.0_21-b07)

Cliente VM Java HotSpot (TM) (versão 17.0-b17, modo misto, compartilhamento)

Mac

versão java "1.6.0_21"

Java (TM) SE Runtime Environment (build 1.6.0_21-b07)

Servidor VM Java HotSpot (TM) de 64 bits (versão 17.0-b17, modo misto, compartilhamento)

Etapa 2: configurar o Java Development Kit (JDK)

Se você não tiver o Java instalado, poderá instalar o Java Software Development Kit (SDK) do site Java da Oracle - Java SE Downloads . Você encontrará instruções para instalar o JDK nos arquivos baixados, siga as instruções fornecidas para instalar e configurar a configuração. Finalmente, defina as variáveis ​​de ambiente PATH e JAVA_HOME para se referir ao diretório que contém java e javac, normalmente java_install_dir / bin e java_install_dir respectivamente.

Colocou o JAVA_HOME variável de ambiente para apontar para o local do diretório base onde o Java está instalado em sua máquina.

Por exemplo -

SO Resultado
janelas Defina a variável de ambiente JAVA_HOME como C: \ Arquivos de programas \ Java \ jdk1.6.0_21
Linux Exportar JAVA_HOME = / usr / local / java-current
Mac Exportar JAVA_HOME = / Library / Java / Home

Anexe a localização do compilador Java ao caminho do sistema.

SO Resultado
janelas Anexe a string;% JAVA_HOME% \ bin ao final da variável do sistema, Caminho.
Linux Exportar PATH =$PATH:$JAVA_HOME / bin /
Mac Não requerido

Como alternativa, se você usar um Ambiente de Desenvolvimento Integrado (IDE) como Borland JBuilder, Eclipse, IntelliJ IDEA ou Sun ONE Studio, compile e execute um programa simples para confirmar que o IDE sabe onde você instalou o Java. Caso contrário, execute uma configuração adequada de acordo com o documento fornecido do IDE.

Etapa 3: Configurar IDE Eclipse

Todos os exemplos neste tutorial foram escritos usando Eclipse IDE. Portanto, sugerimos que você tenha a versão mais recente do Eclipse instalada em sua máquina com base em seu sistema operacional.

Para instalar o Eclipse IDE, baixe os binários mais recentes do Eclipse com suporte WTP em https://www.eclipse.org/downloads/. Depois de baixar a instalação, descompacte a distribuição binária em um local conveniente. Por exemplo, em C: \ eclipse no Windows ou / usr / local / eclipse no Linux / Unix e, finalmente, defina a variável PATH apropriadamente.

O Eclipse pode ser iniciado executando os seguintes comandos na máquina Windows ou você pode simplesmente clicar duas vezes em eclipse.exe

%C:\eclipse\eclipse.exe

O Eclipse pode ser iniciado executando os seguintes comandos na máquina Unix (Solaris, Linux, etc.) -

$/usr/local/eclipse/eclipse

Após uma inicialização bem-sucedida, se tudo estiver bem, ele exibirá o seguinte resultado.

*Note - Instale o plugin m2eclipse para eclipse usando o seguinte site de atualização de software eclipse

Plugin m2eclipse - https://m2eclipse.sonatype.org/update/.

Este plugin permite que os desenvolvedores executem comandos maven dentro do eclipse com instalação embutida / externa do maven.

Etapa 4: Baixe o arquivo Maven

Baixe o Maven 2.2.1 de https://maven.apache.org/download.html

SO Nome do arquivo
janelas apache-maven-2.0.11-bin.zip
Linux apache-maven-2.0.11-bin.tar.gz
Mac apache-maven-2.0.11-bin.tar.gz

Etapa 5: Extraia o arquivo Maven

Extraia o arquivo para o diretório em que deseja instalar o Maven 2.2.1. O subdiretório apache-maven-2.2.1 será criado a partir do arquivo.

SO Localização (pode ser diferente com base na sua instalação)
janelas C: \ Arquivos de programas \ Apache Software Foundation \ apache-maven-2.2.1
Linux / usr / local / apache-maven
Mac / usr / local / apache-maven

Etapa 6: definir as variáveis ​​de ambiente Maven

Adicione M2_HOME, M2, MAVEN_OPTS às variáveis ​​de ambiente.

SO Resultado
janelas

Defina as variáveis ​​de ambiente usando propriedades do sistema.

M2_HOME = C: \ Arquivos de programas \ Apache Software Foundation \ apachemaven-2.2.1

M2 =% M2_HOME% \ bin

MAVEN_OPTS = -Xms256m -Xmx512m

Linux

Abra o terminal de comando e defina as variáveis ​​de ambiente.

export M2_HOME = / usr / local / apache-maven / apache-maven-2.2.1

exportar M2 =% M2_HOME% \ bin

export MAVEN_OPTS = -Xms256m -Xmx512m

Mac

Abra o terminal de comando e defina as variáveis ​​de ambiente.

export M2_HOME = / usr / local / apache-maven / apache-maven-2.2.1

exportar M2 =% M2_HOME% \ bin

export MAVEN_OPTS = -Xms256m -Xmx512m

Etapa 7: adicione o local do diretório bin do Maven ao caminho do sistema

Agora anexe a variável M2 ao caminho do sistema.

SO Resultado
janelas Anexe a string;% M2% ao final da variável do sistema, Caminho.
Linux exportar PATH = $ M2: $ PATH
Mac exportar PATH = $ M2: $ PATH

Etapa 8: Verifique a instalação do Maven.

Abra o console e execute o seguinte comando mvn.

SO Tarefa Comando
janelas Abrir console de comando c: \> mvn --version
Linux Abra o terminal de comando $ mvn --version
Mac Terminal aberto máquina: ~ joseph $ mvn --version

Finalmente, verifique a saída dos comandos acima, que devem ser mostrados na tabela a seguir.

SO Resultado
janelas

Apache Maven 2.2.1 (r801777; 07/08/2009 00: 46: 01 + 0530)

Versão Java: 1.6.0_21

Página inicial do Java: C: \ Arquivos de programas \ Java \ jdk1.6.0_21 \ jre

Linux

Apache Maven 2.2.1 (r801777; 07/08/2009 00: 46: 01 + 0530)

Versão Java: 1.6.0_21

Página inicial do Java: C: \ Arquivos de programas \ Java \ jdk1.6.0_21 \ jre

Mac

Apache Maven 2.2.1 (r801777; 07/08/2009 00: 46: 01 + 0530)

Versão Java: 1.6.0_21

Página inicial do Java: C: \ Arquivos de programas \ Java \ jdk1.6.0_21 \ jre

Etapa 9: configurar o Apache Tomcat

Você pode baixar a versão mais recente do Tomcat em https://tomcat.apache.org/. Depois de baixar a instalação, descompacte a distribuição binária em um local conveniente. Por exemplo, em C: \ apache-tomcat-6.0.33 no Windows ou /usr/local/apache-tomcat-6.0.33 no Linux / Unix e defina a variável de ambiente CATALINA_HOME apontando para os locais de instalação.

O Tomcat pode ser iniciado executando os seguintes comandos em uma máquina Windows ou você pode simplesmente clicar duas vezes em startup.bat

%CATALINA_HOME%\bin\startup.bat 
or 
C:\apache-tomcat-6.0.33\bin\startup.bat

O Tomcat pode ser iniciado executando os seguintes comandos na máquina Unix (Solaris, Linux, etc.).

$CATALINA_HOME/bin/startup.sh 
or 
/usr/local/apache-tomcat-6.0.33/bin/startup.sh

Após uma inicialização bem-sucedida, os aplicativos da web padrão incluídos no Tomcat estarão disponíveis visitando http://localhost:8080/. Se tudo estiver bem, ele exibirá o seguinte resultado.

Mais informações sobre como configurar e executar o Tomcat podem ser encontradas na documentação incluída aqui, bem como no site do Tomcat - http://tomcat.apache.org

O Tomcat pode ser interrompido executando os seguintes comandos na máquina Windows.

%CATALINA_HOME%\bin\shutdown 
or 
C:\apache-tomcat-5.5.29\bin\shutdown

O Tomcat pode ser interrompido executando os seguintes comandos na máquina Unix (Solaris, Linux, etc.).

$CATALINA_HOME/bin/shutdown.sh 
or 
/usr/local/apache-tomcat-5.5.29/bin/shutdown.sh

A tecnologia JSF é uma estrutura para desenvolver, construir componentes de interface do usuário do lado do servidor e usá-los em um aplicativo da web. A tecnologia JSF é baseada na arquitetura Model View Controller (MVC) para separar a lógica da apresentação.

O que é MVC Design Pattern?

O padrão de design MVC projeta um aplicativo usando três módulos separados -

S.No Módulo e Descrição
1

Model

Carrega dados e login

2

View

Mostra a interface do usuário

3

Controller

Lida com o processamento de um aplicativo.

O objetivo do padrão de design MVC é separar o modelo e a apresentação, permitindo que os desenvolvedores se concentrem em suas habilidades principais e colaborem de forma mais clara.

Os web designers precisam se concentrar apenas na camada de visualização, em vez de na camada do modelo e do controlador. Os desenvolvedores podem alterar o código do modelo e normalmente não precisam alterar a camada de visualização. Os controladores são usados ​​para processar ações do usuário. Neste processo, o modelo da camada e as vistas podem ser alterados.

Arquitetura JSF

O aplicativo JSF é semelhante a qualquer outro aplicativo da web baseado na tecnologia Java; ele é executado em um contêiner de servlet Java e contém -

  • Componentes JavaBeans como modelos contendo funcionalidades e dados específicos do aplicativo

  • Uma biblioteca de tags personalizadas para representar manipuladores e validadores de eventos

  • Uma biblioteca de tags personalizadas para renderizar componentes da IU

  • Componentes da IU representados como objetos com estado no servidor

  • Classes auxiliares do lado do servidor

  • Validadores, manipuladores de eventos e manipuladores de navegação

  • Arquivo de recurso de configuração de aplicativo para configurar recursos de aplicativo

Existem controladores que podem ser usados ​​para realizar ações do usuário. A IU pode ser criada por autores de páginas da web e a lógica de negócios pode ser utilizada por beans gerenciados.

JSF fornece vários mecanismos para renderizar um componente individual. Cabe ao designer da página da web escolher a representação desejada e o desenvolvedor do aplicativo não precisa saber qual mecanismo foi usado para renderizar um componente de IU do JSF.

O ciclo de vida do aplicativo JSF consiste em seis fases, que são as seguintes -

  • Fase de visualização de restauração
  • Aplicar fase de valores de solicitação; eventos de processo
  • Fase de validação do processo; eventos de processo
  • Fase de atualização dos valores do modelo; eventos de processo
  • Chamar fase de aplicação; eventos de processo
  • Fase de resposta de renderização

As seis fases mostram a ordem em que o JSF processa um formulário. A lista mostra as fases em sua provável ordem de execução com processamento de eventos em cada fase.

Fase 1: Restaurar vista

O JSF começa a fase de restauração da visualização assim que um link ou botão é clicado e o JSF recebe uma solicitação.

Durante esta fase, o JSF constrói a visualização, conecta manipuladores de eventos e validadores aos componentes da IU e salva a visualização na instância FacesContext. A instância FacesContext agora conterá todas as informações necessárias para processar uma solicitação.

Fase 2: Aplicar valores de solicitação

Depois que a árvore de componentes é criada / restaurada, cada componente na árvore de componentes usa o método de decodificação para extrair seu novo valor dos parâmetros de solicitação. O componente armazena esse valor. Se a conversão falhar, uma mensagem de erro será gerada e enfileirada no FacesContext. Esta mensagem será exibida durante a fase de resposta de renderização, juntamente com quaisquer erros de validação.

Se houver ouvintes de eventos de métodos de decodificação chamados renderResponse na instância FacesContext atual, o JSF passa para a fase de resposta de renderização.

Fase 3: Validação do processo

Durante esta fase, o JSF processa todos os validadores registrados na árvore de componentes. Ele examina as regras de atributo do componente para a validação e compara essas regras com o valor local armazenado para o componente.

Se o valor local for inválido, o JSF adiciona uma mensagem de erro à instância FacesContext e o ciclo de vida avança para a fase de resposta de renderização e exibe a mesma página novamente com a mensagem de erro.

Fase 4: Atualizar os valores do modelo

Depois que o JSF verifica se os dados são válidos, ele percorre a árvore de componentes e define as propriedades do objeto do lado do servidor correspondentes para os valores locais dos componentes. O JSF atualizará as propriedades do bean correspondentes ao atributo de valor do componente de entrada.

Se algum método updateModels for chamado de renderResponse na instância FacesContext atual, o JSF irá para a fase de resposta de renderização.

Fase 5: invocar aplicativo

Durante esta fase, o JSF lida com qualquer evento de nível de aplicativo, como o envio de um formulário / link para outra página.

Fase 6: Renderizar a resposta

Durante esta fase, o JSF pede ao servidor de contêiner / aplicativo para renderizar a página se o aplicativo estiver usando páginas JSP. Para a solicitação inicial, os componentes representados na página serão adicionados à árvore de componentes conforme o contêiner JSP executa a página. Se esta não for uma solicitação inicial, a árvore de componentes já foi construída, portanto os componentes não precisam ser adicionados novamente. Em ambos os casos, os componentes serão renderizados conforme o contêiner JSP / servidor de aplicativos atravessa as tags na página.

Depois que o conteúdo da visualização é renderizado, o estado de resposta é salvo para que as solicitações subsequentes possam acessá-lo e ficar disponível para a fase de restauração da visualização.

Para criar um aplicativo JSF simples, usaremos o plugin maven-archetype-webapp. No exemplo a seguir, criaremos um projeto de aplicativo da web baseado em maven na pasta C: \ JSF.

Criar Projeto

Vamos abrir o console de comando, vá para C:\ > JSF diretório e execute o seguinte mvn comando.

C:\JSF>mvn archetype:create  
-DgroupId = com.tutorialspoint.test  
-DartifactId = helloworld  
-DarchetypeArtifactId = maven-archetype-webapp

O Maven iniciará o processamento e criará a estrutura completa do projeto da aplicação web java.

[INFO] Scanning for projects... 
[INFO] Searching repository for plugin with prefix: 'archetype'. 
[INFO] ------------------------------------------------------------- 
[INFO] Building Maven Default Project 
[INFO]    task-segment: [archetype:create] (aggregator-style) 
[INFO] ------------------------------------------------------------- 
[INFO] [archetype:create {execution: default-cli}] 
[INFO] Defaulting package to group ID: com.tutorialspoint.test 
[INFO] artifact org.apache.maven.archetypes:maven-archetype-webapp:  
checking for updates from central 
[INFO] ------------------------------------------------------------- 
[INFO] Using following parameters for creating project  
from Old (1.x) Archetype: maven-archetype-webapp:RELEASE 
[INFO] ------------------------------------------------------------- 
[INFO] Parameter: groupId, Value: com.tutorialspoint.test 
[INFO] Parameter: packageName, Value: com.tutorialspoint.test 
[INFO] Parameter: package, Value: com.tutorialspoint.test 
[INFO] Parameter: artifactId, Value: helloworld 
[INFO] Parameter: basedir, Value: C:\JSF 
[INFO] Parameter: version, Value: 1.0-SNAPSHOT 
[INFO] project created from Old (1.x) Archetype in dir: 
C:\JSF\helloworld 
[INFO] ------------------------------------------------------------- 
[INFO] BUILD SUCCESSFUL 
[INFO] ------------------------------------------------------------- 
[INFO] Total time: 7 seconds 
[INFO] Finished at: Mon Nov 05 16:05:04 IST 2012 
[INFO] Final Memory: 12M/84M 
[INFO] -------------------------------------------------------------

Agora vá para o diretório C: / JSF. Você verá um projeto de aplicativo da web Java criado, denominado helloworld (conforme especificado em artifactId). O Maven usa um layout de diretório padrão, conforme mostrado na captura de tela a seguir.

Usando o exemplo acima, podemos entender os seguintes conceitos-chave.

S.No Estrutura e descrição da pasta
1

helloworld

Contém a pasta src e pom.xml

2

src/main/wepapp

Contém a pasta WEB-INF e a página index.jsp

3

src/main/resources

Ele contém arquivos de imagens / propriedades (no exemplo acima, precisamos criar esta estrutura manualmente)

Adicionar capacidade JSF ao projeto

Adicione as seguintes dependências JSF.

<dependencies>
   <dependency>
      <groupId>com.sun.faces</groupId>
      <artifactId>jsf-api</artifactId>
      <version>2.1.7</version>
   </dependency>
	
   <dependency>
      <groupId>com.sun.faces</groupId>
      <artifactId>jsf-impl</artifactId>
      <version>2.1.7</version>
   </dependency>
	
</dependencies>

POM.xml completo

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
   http://maven.apache.org/maven-v4_0_0.xsd">
	
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint.test</groupId>
   <artifactId>helloworld</artifactId>
   <packaging>war</packaging>
   <version>1.0-SNAPSHOT</version>
   <name>helloworld Maven Webapp</name>
   <url>http://maven.apache.org</url>
	
   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
      </dependency>
		
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-api</artifactId>
         <version>2.1.7</version>
      </dependency>
		
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-impl</artifactId>
         <version>2.1.7</version>
      </dependency>
		
   </dependencies>
	
   <build>
      <finalName>helloworld</finalName>
      <plugins>
         <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.3.1</version>
				
            <configuration>
               <source>1.6</source>
               <target>1.6</target>
            </configuration>
         </plugin>
      </plugins>
   
   </build>		
</project>

Prepare o Projeto Eclipse

Vamos abrir o console de comando. Vai aC:\ > JSF > helloworld diretório e execute o seguinte mvn comando.

C:\JSF\helloworld>mvn eclipse:eclipse -Dwtpversion = 2.0

O Maven iniciará o processamento, criará o projeto pronto para eclipse e adicionará o recurso wtp.

Downloading: http://repo.maven.apache.org/org/apache/maven/plugins/
maven-compiler-plugin/2.3.1/maven-compiler-plugin-2.3.1.pom
5K downloaded  (maven-compiler-plugin-2.3.1.pom)
Downloading: http://repo.maven.apache.org/org/apache/maven/plugins/
maven-compiler-plugin/2.3.1/maven-compiler-plugin-2.3.1.jar
29K downloaded  (maven-compiler-plugin-2.3.1.jar)
[INFO] Searching repository for plugin with prefix: 'eclipse'.
[INFO] ------------------------------------------------------------
[INFO] Building helloworld Maven Webapp
[INFO]    task-segment: [eclipse:eclipse]
[INFO] ------------------------------------------------------------
[INFO] Preparing eclipse:eclipse
[INFO] No goals needed for project - skipping
[INFO] [eclipse:eclipse {execution: default-cli}]
[INFO] Adding support for WTP version 2.0.
[INFO] Using Eclipse Workspace: null
[INFO] Adding default classpath container: org.eclipse.jdt.
launching.JRE_CONTAINER
Downloading: http://repo.maven.apache.org/
com/sun/faces/jsf-api/2.1.7/jsf-api-2.1.7.pom
12K downloaded  (jsf-api-2.1.7.pom)
Downloading: http://repo.maven.apache.org/
com/sun/faces/jsf-impl/2.1.7/jsf-impl-2.1.7.pom
10K downloaded  (jsf-impl-2.1.7.pom)
Downloading: http://repo.maven.apache.org/
com/sun/faces/jsf-api/2.1.7/jsf-api-2.1.7.jar
619K downloaded  (jsf-api-2.1.7.jar)
Downloading: http://repo.maven.apache.org/
com/sun/faces/jsf-impl/2.1.7/jsf-impl-2.1.7.jar
1916K downloaded  (jsf-impl-2.1.7.jar)
[INFO] Wrote settings to C:\JSF\helloworld\.settings\
org.eclipse.jdt.core.prefs
[INFO] Wrote Eclipse project for "helloworld" to C:\JSF\helloworld.
[INFO]
[INFO] -----------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] -----------------------------------------------------------
[INFO] Total time: 6 minutes 7 seconds
[INFO] Finished at: Mon Nov 05 16:16:25 IST 2012
[INFO] Final Memory: 10M/89M
[INFO] -----------------------------------------------------------

Importar projeto no Eclipse

A seguir estão as etapas -

  • Importe o projeto no eclipse usando o assistente de importação.

  • Vamos para File → Import... → Existing project into workspace.

  • Selecione o diretório raiz para helloworld.

  • Manter Copy projects into workspace a ser checado.

  • Clique no botão Concluir.

  • O Eclipse importará e copiará o projeto em seu espaço de trabalho C:\ → Projects → Data → WorkSpace.

Configure o Faces Servlet em web.xml

Localize web.xml em webapp → WEB-INF pasta e atualize-a conforme mostrado abaixo.

<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xmlns = "http://java.sun.com/xml/ns/javaee" 
   xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
   id = "WebApp_ID" version="2.5">
	
   <welcome-file-list>
      <welcome-file>faces/home.xhtml</welcome-file>
   </welcome-file-list>
	
   <!-- 
      FacesServlet is main servlet responsible to handle all request. 
      It acts as central controller.
      This servlet initializes the JSF components before the JSP is displayed.
   -->
	
   <servlet>
      <servlet-name>Faces Servlet</servlet-name>
      <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
      <load-on-startup>1</load-on-startup>
   </servlet>
	
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>/faces/*</url-pattern>
   </servlet-mapping>
	
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.jsf</url-pattern>
   </servlet-mapping>
	
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.faces</url-pattern>
   </servlet-mapping>
	
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.xhtml</url-pattern>
   </servlet-mapping>
	
</web-app>

Criar um bean gerenciado

Crie uma estrutura de pacote em src → main → java as com → tutorialspoint → test. Crie a classe HelloWorld.java neste pacote. Atualize o código deHelloWorld.java como mostrado abaixo.

package com.tutorialspoint.test;

import javax.faces.bean.ManagedBean;

@ManagedBean(name = "helloWorld", eager = true)
public class HelloWorld {
   
   public HelloWorld() {
      System.out.println("HelloWorld started!");
   }
	
   public String getMessage() {
      return "Hello World!";
   }
}

Crie uma página JSF

Crie uma página home.xhtml em webapppasta. Atualize o código dehome.xhtml como mostrado abaixo.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml">
   <head>
      <title>JSF Tutorial!</title>
   </head>

   <body>
      #{helloWorld.getMessage()}
   </body>
</html>

Construir o Projeto

A seguir estão as etapas.

  • Selecione o projeto helloworld em eclipse

  • Use o assistente Executar como

  • Selecione Run As → Maven package

  • Maven começará a construir o projeto e criará helloworld.war sob C:\ → Projects → Data → WorkSpace → helloworld → target pasta.

[INFO] Scanning for projects...
[INFO] -----------------------------------------------------
[INFO] Building helloworld Maven Webapp
[INFO] 
[INFO] Id: com.tutorialspoint.test:helloworld:war:1.0-SNAPSHOT
[INFO] task-segment: [package]
[INFO] -----------------------------------------------------
[INFO] [resources:resources]
[INFO] Using default encoding to copy filtered resources.
[INFO] [compiler:compile]
[INFO] Nothing to compile - all classes are up to date
[INFO] [resources:testResources]
[INFO] Using default encoding to copy filtered resources.
[INFO] [compiler:testCompile]
[INFO] No sources to compile
[INFO] [surefire:test]
[INFO] Surefire report directory: 
C:\Projects\Data\WorkSpace\helloworld\target\surefire-reports

-------------------------------------------------------
 T E S T S
-------------------------------------------------------
There are no tests to run.

Results :

Tests run: 0, Failures: 0, Errors: 0, Skipped: 0

[INFO] [war:war]
[INFO] Packaging webapp
[INFO] Assembling webapp[helloworld] in
[C:\Projects\Data\WorkSpace\helloworld\target\helloworld]
[INFO] Processing war project
[INFO] Webapp assembled in[150 msecs]
[INFO] Building war: 
C:\Projects\Data\WorkSpace\helloworld\target\helloworld.war
[INFO] ------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------
[INFO] Total time: 3 seconds
[INFO] Finished at: Mon Nov 05 16:34:46 IST 2012
[INFO] Final Memory: 2M/15M
[INFO] ------------------------------------------------

Implantar arquivo WAR

A seguir estão as etapas.

  • Pare o servidor tomcat.

  • Copie o arquivo helloworld.war para tomcat installation directory → webapps folder.

  • Inicie o servidor tomcat.

  • Olhe dentro do diretório webapps, deve haver uma pasta helloworld foi criada.

  • Agora helloworld.war foi implementado com sucesso na raiz do Tomcat Webserver.

Executar aplicativo

Insira um url no navegador da web: http://localhost:8080/helloworld/home.jsf para iniciar o aplicativo.

O nome do servidor (localhost) e a porta (8080) podem variar de acordo com a configuração do tomcat.

Managed Bean é uma classe regular Java Bean registrada com JSF. Em outras palavras, Managed Beans é um Java bean gerenciado pela estrutura JSF. O bean gerenciado contém os métodos getter e setter, lógica de negócios ou até mesmo um bean de apoio (um bean contém todo o valor do formulário HTML).

Beans gerenciados funcionam como modelo para o componente UI. O Managed Bean pode ser acessado na página JSF.

Dentro JSF 1.2, um bean gerenciado precisava registrá-lo no arquivo de configuração JSF, como facesconfig.xml. DeJSF 2.0em diante, os beans gerenciados podem ser facilmente registrados usando anotações. Essa abordagem mantém os beans e seu registro em um local, portanto, torna-se mais fácil de gerenciar.

Usando configuração XML

<managed-bean>
   <managed-bean-name>helloWorld</managed-bean-name>
   <managed-bean-class>com.tutorialspoint.test.HelloWorld</managed-bean-class>
   <managed-bean-scope>request</managed-bean-scope>
</managed-bean> 

<managed-bean>
   <managed-bean-name>message</managed-bean-name>
   <managed-bean-class>com.tutorialspoint.test.Message</managed-bean-class>
   <managed-bean-scope>request</managed-bean-scope>
</managed-bean>

Usando Anotação

@ManagedBean(name = "helloWorld", eager = true)
@RequestScoped
public class HelloWorld {
   @ManagedProperty(value = "#{message}")
   private Message message;
   ...
}

@ManagedBean Annotation

@ManagedBeanmarca um bean como um bean gerenciado com o nome especificado no atributo name. Se o atributo name não for especificado, o nome do bean gerenciado assumirá como padrão a parte do nome da classe do nome da classe totalmente qualificado. No nosso caso, seria helloWorld.

Outro atributo importante é eager. Se eager = "true", o bean gerenciado é criado antes de ser solicitado pela primeira vez, caso contrário, a inicialização "preguiçosa" é usada em que o bean será criado apenas quando for solicitado.

Anotações de escopo

As anotações de escopo definem o escopo no qual o bean gerenciado será colocado. Se o escopo não for especificado, o bean assumirá como padrão o escopo de solicitação. Cada escopo é brevemente discutido na tabela a seguir.

S.No Escopo e descrição
1

@RequestScoped

Bean vive enquanto vive a solicitação-resposta HTTP. Ele é criado em uma solicitação HTTP e destruído quando a resposta HTTP associada à solicitação HTTP é concluída.

2

@NoneScoped

O feijão dura tanto quanto uma única avaliação EL. Ele é criado em uma avaliação EL e destruído imediatamente após a avaliação EL.

3

@ViewScoped

O bean vive enquanto o usuário está interagindo com a mesma visualização JSF na janela / guia do navegador. Ele é criado por meio de uma solicitação HTTP e destruído assim que o usuário postar em uma visualização diferente.

4

@SessionScoped

Bean dura tanto quanto dura a sessão HTTP. Ele é criado na primeira solicitação HTTP envolvendo este bean na sessão e é destruído quando a sessão HTTP é invalidada.

5

@ApplicationScoped

Bean vive enquanto vive o aplicativo da web. Ele é criado na primeira solicitação de HTTP envolvendo este bean no aplicativo (ou quando o aplicativo da web é inicializado e o atributo eager = true é definido em @ManagedBean) e é destruído quando o aplicativo da web é encerrado.

6

@CustomScoped

O bean dura tanto quanto a entrada do bean no mapa customizado, que é criado para este escopo.

@ManagedProperty Annotation

JSF é uma estrutura simples de injeção de dependência (DI) estática. Usando@ManagedProperty anotação, a propriedade de um bean gerenciado pode ser injetada em outro bean gerenciado.

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar as anotações acima para beans gerenciados.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Criar aplicativo .
2 Modifique HelloWorld.java conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
3 Crie Message.java em um pacote com.tutorialspoint.test conforme explicado abaixo.
4 Compile e execute o aplicativo para ter certeza de que a lógica de negócios está funcionando de acordo com os requisitos.
5 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
6 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

HelloWorld.java

package com.tutorialspoint.test;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.ManagedProperty;
import javax.faces.bean.RequestScoped;

@ManagedBean(name = "helloWorld", eager = true)
@RequestScoped
public class HelloWorld {
   @ManagedProperty(value = "#{message}")
   private Message messageBean;
   private String message;
   
   public HelloWorld() {
      System.out.println("HelloWorld started!");   
   }
   
   public String getMessage() {
      
      if(messageBean != null) {
         message = messageBean.getMessage();
      }       
      return message;
   }
   
   public void setMessageBean(Message message) {
      this.messageBean = message;
   }
}

Message.java

package com.tutorialspoint.test;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;

@ManagedBean(name = "message", eager = true)
@RequestScoped
public class Message {
   private String message = "Hello World!";
	
   public String getMessage() {
      return message;
   }
   public void setMessage(String message) {
      this.message = message;
   }
}

home.xhtml

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml">
   <head>
      <title>JSF Tutorial!</title>
   </head>
   
   <body>
      #{helloWorld.message}
   </body>
</html>

Quando você estiver pronto com todas as alterações feitas, vamos compilar e executar o aplicativo como fizemos no capítulo JSF - Criar Aplicativo. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

As regras de navegação são as regras fornecidas pelo JSF Framework que descreve qual visualização deve ser mostrada quando um botão ou link é clicado.

As regras de navegação podem ser definidas no arquivo de configuração JSF denominado faces-config.xml. Eles podem ser definidos em beans gerenciados.

As regras de navegação podem conter condições com base nas quais a visualização dos resultados pode ser mostrada. O JSF 2.0 também fornece navegação implícita em que não há necessidade de definir regras de navegação como tal.

Navegação implícita

JSF 2.0 fornece auto view page resolver mecanismo denominado implicit navigation. Neste caso, você só precisa colocar o nome da visão no atributo de ação e o JSF irá pesquisar o corretoview página automaticamente no aplicativo implementado.

Navegação automática na página JSF

Defina o nome da visualização no atributo de ação de qualquer componente de interface do usuário JSF.

<h:form>
   <h3>Using JSF outcome</h3>
   <h:commandButton action = "page2" value = "Page2" />
</h:form>

Aqui quando Page2 botão for clicado, o JSF resolverá o nome da visualização, page2 como extensão page2.xhtml e encontre o arquivo de visualização correspondente page2.xhtml no diretório atual.

Navegação automática no Managed Bean

Defina um método no managed bean para retornar um nome de visão.

@ManagedBean(name = "navigationController", eager = true)
@RequestScoped

public class NavigationController implements Serializable {
   public String moveToPage1() {
      return "page1";
   }
}

Obtenha o nome da visualização no atributo de ação de qualquer componente de interface do usuário JSF usando o bean gerenciado.

<h:form> 
   <h3> Using Managed Bean</h3>  
   <h:commandButton action = "#{navigationController.moveToPage1}" 
   value = "Page1" /glt; 
</h:form>

Aqui quando Page1 botão for clicado, o JSF resolverá o nome da visualização, page1 como extensão page1.xhtml e encontre o arquivo de visualização correspondente page1.xhtml no diretório atual.

Navegação Condicional

Usando o bean gerenciado, podemos controlar facilmente a navegação. Observe o seguinte código em um bean gerenciado.

@ManagedBean(name = "navigationController", eager = true)
@RequestScoped

public class NavigationController implements Serializable {
   //this managed property will read value from request parameter pageId
   @ManagedProperty(value = "#{param.pageId}")
   private String pageId;

   //condional navigation based on pageId
   //if pageId is 1 show page1.xhtml,
   //if pageId is 2 show page2.xhtml
   //else show home.xhtml
   
   public String showPage() {
      if(pageId == null) {
         return "home";
      }
      
      if(pageId.equals("1")) {
         return "page1";
      }else if(pageId.equals("2")) {
         return "page2";
      }else {
         return "home";
      }
   }
}

Passe pageId como um parâmetro de solicitação no JSF UI Component.

<h:form>
   <h:commandLink action = "#{navigationController.showPage}" value = "Page1">
      <f:param name = "pageId" value = "1" />
   </h:commandLink>
   <h:commandLink action = "#{navigationController.showPage}" value = "Page2">
      <f:param name = "pageId" value = "2" />
   </h:commandLink>
   <h:commandLink action = "#{navigationController.showPage}" value = "Home">
      <f:param name = "pageId" value = "3" />
   </h:commandLink>
</h:form>

Aqui, quando o botão "Página1" é clicado.

  • JSF irá criar uma solicitação com o parâmetro pageId = 1

  • Em seguida, o JSF passará este parâmetro para a propriedade gerenciada pageId de navigationController

  • Agora navigationController.showPage () é chamado, o que retornará a visualização como page1 após verificar o pageId

  • JSF resolverá o nome da visualização, page1 como extensão page1.xhtml

  • Encontre o arquivo de visualização correspondente page1.xhtml no diretório atual

Resolvendo a navegação com base na ação inicial

JSF fornece opção de resolução de navegação mesmo se métodos diferentes de bean gerenciado retornarem o mesmo nome de visualização.

Observe o seguinte código em um bean gerenciado.

public String processPage1() { 
   return "page"; 
} 
public String processPage2() { 
   return "page"; 
}

Para resolver as visualizações, defina as seguintes regras de navegação em faces-config.xml

<navigation-rule> 
   <from-view-id>home.xhtml</from-view-id> 
   
   <navigation-case> 
      <from-action>#{navigationController.processPage1}</from-action> 
      <from-outcome>page</from-outcome> 
      <to-view-id>page1.jsf</to-view-id> 
   </navigation-case> 
   
   <navigation-case> 
      <from-action>#{navigationController.processPage2}</from-action> 
      <from-outcome>page</from-outcome> 
      <to-view-id>page2.jsf</to-view-id> 
   </navigation-case> 

</navigation-rule>

Aqui, quando o botão Página1 é clicado -

  • navigationController.processPage1() é chamado, o que retornará a visualização como página

  • JSF resolverá o nome da visão, page1 como o nome da vista é page and from-action dentro faces-config is navigationController.processPage1

  • Encontre o arquivo de visualização correspondente page1.xhtml no diretório atual

Avançar vs Redirecionar

O JSF, por padrão, executa um encaminhamento de página do servidor enquanto navega para outra página e a URL do aplicativo não muda.

Para habilitar o redirecionamento de página, anexe faces-redirect=true no final do nome da visualização.

<h:form>
   <h3>Forward</h3>
   <h:commandButton action = "page1" value = "Page1" />
   <h3>Redirect</h3>
   <h:commandButton action = "page1?faces-redirect = true" value = "Page1" />
</h:form>

Aqui quando Page1 botão sob Forward for clicado, você obterá o seguinte resultado.

Aqui quando Page1 botão sob Redirect for clicado, você obterá o seguinte resultado.

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar todos os exemplos de navegação acima.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Criar aplicativo .
2 Crie NavigationController.java sob um pacote com.tutorialspoint.test conforme explicado abaixo.
3 Crie faces-config.xml em uma pasta WEB-INF e atualize seu conteúdo conforme explicado abaixo.
4 Atualize web.xml em uma pasta WEB-INF conforme explicado abaixo.
5 Crie page1.xhtml e page2.xhtml e modifique home.xhtml em uma pasta de webapp conforme explicado abaixo.
6 Compile e execute o aplicativo para ter certeza de que a lógica de negócios está funcionando de acordo com os requisitos.
7 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
8 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

NavigationController.java

package com.tutorialspoint.test;
  
import java.io.Serializable;  

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ManagedProperty; 
import javax.faces.bean.RequestScoped;  

@ManagedBean(name = "navigationController", eager = true) 
@RequestScoped 
public class NavigationController implements Serializable {  
   private static final long serialVersionUID = 1L;  
   @ManagedProperty(value = "#{param.pageId}")    
   private String pageId;  
   
   public String moveToPage1() {      
      return "page1";    
   }  
   
   public String moveToPage2() {       
      return "page2";    
   }  
   
   public String moveToHomePage() {      
      return "home";    
   }  
   
   public String processPage1() {       
      return "page";    
   }  
   
   public String processPage2() {       
      return "page";    
   } 
   
   public String showPage() {       
      if(pageId == null) {          
         return "home";       
      }       
      
      if(pageId.equals("1")) {          
         return "page1";       
      }else if(pageId.equals("2")) {          
         return "page2";       
      }else {          
         return "home";       
      }    
   }  
   
   public String getPageId() {       
      return pageId;    
   }  
   
   public void setPageId(String pageId) {       
      this.pageId = pageId;   
   } 
}

faces-config.xml

<?xml version = "1.0" encoding = "UTF-8"?>

<faces-config
   xmlns = "http://java.sun.com/xml/ns/javaee"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
   http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
   version = "2.0">
   
   <navigation-rule>
      <from-view-id>home.xhtml</from-view-id>
      <navigation-case>
         <from-action>#{navigationController.processPage1}</from-action>
         <from-outcome>page</from-outcome>
         <to-view-id>page1.jsf</to-view-id>
      </navigation-case>
      <navigation-case>
         <from-action>#{navigationController.processPage2}</from-action>
         <from-outcome>page</from-outcome>
         <to-view-id>page2.jsf</to-view-id>
      </navigation-case>
   </navigation-rule>

</faces-config>

web.xml

<!DOCTYPE web-app PUBLIC
   "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
   "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
   <display-name>Archetype Created Web Application</display-name>

   <context-param>
      <param-name>javax.faces.PROJECT_STAGE</param-name>
      <param-value>Development</param-value>
   </context-param>
   <context-param>
      <param-name>javax.faces.CONFIG_FILES</param-name>
      <param-value>/WEB-INF/faces-config.xml</param-value>
   </context-param>
   
   <servlet>
      <servlet-name>Faces Servlet</servlet-name>
      <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
   </servlet>
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.jsf</url-pattern>
   </servlet-mapping>

</web-app>

page1.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:body>
      <h2>This is Page1</h2>
      <h:form>
         <h:commandButton action = "home?faces-redirect = true"
            value = "Back To Home Page" />
      </h:form>
   </h:body>
</html>

page2.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:body>
      <h2>This is Page2</h2>
      <h:form>
         <h:commandButton action = "home?faces-redirect = true"
            value = "Back To Home Page" />
      </h:form>
   </h:body>
</html>

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:h = "http://java.sun.com/jsf/html">

   <h:body>
      <h2>Implicit Navigation</h2>
      <hr />
      
      <h:form>
         <h3>Using Managed Bean</h3>
         <h:commandButton action = "#{navigationController.moveToPage1}"
            value = "Page1" />
         <h3>Using JSF outcome</h3>
         <h:commandButton action = "page2" value = "Page2" />
      </h:form>
      <br/>
      
      <h2>Conditional Navigation</h2>
      <hr />
      <h:form>
         <h:commandLink action = "#{navigationController.showPage}"
            value="Page1">
            <f:param name = "pageId" value = "1" />
         </h:commandLink>
              
         
         <h:commandLink action = "#{navigationController.showPage}"
            value="Page2">
            <f:param name = "pageId" value = "2" />
         </h:commandLink>
              
         
         <h:commandLink action = "#{navigationController.showPage}"
            value = "Home">
            <f:param name = "pageId" value = "3" />
         </h:commandLink>
      </h:form>
      <br/>
      
      <h2>"From Action" Navigation</h2>
      <hr />
      
      <h:form>
         <h:commandLink action = "#{navigationController.processPage1}"
         value = "Page1" />
              
         <h:commandLink action = "#{navigationController.processPage2}"
         value = "Page2" />
              
      </h:form>
      <br/>
      
      <h2>Forward vs Redirection Navigation</h2>
      <hr />
      <h:form>
         <h3>Forward</h3>
         <h:commandButton action = "page1" value = "Page1" />
         <h3>Redirect</h3>
         <h:commandButton action = "page1?faces-redirect = true"
         value = "Page1" />
      </h:form>
   </h:body>
</html>

Quando você estiver pronto com todas as alterações feitas, vamos compilar e executar o aplicativo como fizemos no capítulo JSF - Criar Aplicativo. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

Neste capítulo, você aprenderá sobre vários tipos de tags JSF básicas.

JSF fornece uma biblioteca de tags HTML padrão. Essas tags são renderizadas na saída html correspondente.

Para essas tags, você precisa usar os seguintes namespaces de URI no nó html.

<html 
   xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:h = "http://java.sun.com/jsf/html">

A seguir estão as importantes Tags básicas do JSF 2.0.

S.No Tag e descrição
1 h: inputText

Renderiza uma entrada HTML do tipo = "text", caixa de texto.

2 h: inputSecret

Processa uma entrada HTML do tipo = "senha", caixa de texto.

3 h: inputTextarea

Renderiza um campo textarea HTML.

4 h: inputHidden

Renderiza uma entrada HTML do tipo = "oculto".

5 h: selectBooleanCheckbox

Renderiza uma única caixa de seleção HTML.

6 h: selectManyCheckbox

Renderiza um grupo de caixas de seleção HTML.

7 h: selectOneRadio

Renderiza um único botão de rádio HTML.

8 h: selectOneListbox

Renderiza uma única caixa de listagem HTML.

9 h: selectManyListbox

Renderiza uma caixa de listagem múltipla em HTML.

10 h: selectOneMenu

Renderiza uma caixa de combinação HTML.

11 h: outputText

Renderiza um texto HTML.

12 h: outputFormat

Renderiza um texto HTML. Ele aceita parâmetros.

13 h: graphicImage

Renderiza uma imagem.

14 h: outputStylesheet

Inclui uma folha de estilo CSS na saída HTML.

15 h: outputScript

Inclui um script na saída HTML.

16 h: commandButton

Renderiza uma entrada HTML do botão type = "submit".

17 h: Link

Renderiza uma âncora HTML.

18 h: commandLink

Renderiza uma âncora HTML.

19 h: outputLink

Renderiza uma âncora HTML.

20 h: panelGrid

Renderiza uma tabela HTML em forma de grade.

21 h: mensagem

Processa mensagem para um componente de interface do usuário JSF.

22 h: mensagens

Processa todas as mensagens para os componentes de interface do usuário JSF.

23 f: param

Passe parâmetros para o componente JSF UI.

24 f: atributo

Passe o atributo para um componente de IU JSF.

25 f: setPropertyActionListener

Define o valor da propriedade de um bean gerenciado.

O JSF fornece tags especiais para criar um layout comum para um aplicativo da web chamado tags facelets. Essas tags fornecem flexibilidade para gerenciar partes comuns de várias páginas em um só lugar.

Para essas tags, você precisa usar os seguintes namespaces de URI no nó html.

<html  
   xmlns = "http://www.w3.org/1999/xhtml"  
   xmlns:ui = "http://java.sun.com/jsf/facelets">

A seguir, estão as tags Facelets importantes no JSF 2.0.

S.No Tag e descrição
1 Modelos

Vamos demonstrar como usar modelos usando as seguintes tags

  • <ui:insert>
  • <ui:define>
  • <ui:include>
  • <ui:composition>
2 Parâmetros

Vamos demonstrar como passar parâmetros para um arquivo de modelo usando a seguinte tag

  • <ui:param>
3 personalizadas

Vamos demonstrar como criar tags personalizadas

4 Retirar

Vamos demonstrar a capacidade de remover o código JSF da página HTML gerada

O JSF fornece conversores embutidos para converter os dados de seu componente de IU em objeto usado em um bean gerenciado e vice-versa. Por exemplo, essas tags podem converter um texto em objeto de data e podem validar o formato de entrada também.

Para essas tags, você precisa usar os seguintes namespaces de URI no nó html.

<html 
   xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:f = "http://java.sun.com/jsf/core">

A seguir estão as tags conversoras importantes no JSF 2.0 -

S.No Tag e descrição
1 f: convertNumber

Converte uma string em um número do formato desejado

2 f: convertDateTime

Converte uma string em uma data do formato desejado

3 Conversor Personalizado

Criação de um conversor personalizado

O JSF fornece validadores embutidos para validar seus componentes de IU. Essas tags podem validar o comprimento do campo, o tipo de entrada que pode ser um objeto personalizado.

Para essas tags, você precisa usar os seguintes namespaces de URI no nó html.

<html 
   xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:f = "http://java.sun.com/jsf/core">

A seguir estão as tags validadoras importantes no JSF 2.0−

S.No Tag e descrição
1 f: validateLength

Valida o comprimento de uma string

2 f: validateLongRange

Valida o intervalo de um valor numérico

3 f: validateDoubleRange

Valida o intervalo de um valor flutuante

4 f: validateRegex

Valida o componente JSF com uma determinada expressão regular

5 Validador Personalizado

Cria um validador personalizado

JSF fornece um controle avançado denominado DataTable para renderizar e formatar tabelas html.

  • DataTable pode iterar em uma coleção ou matriz de valores para exibir dados.

  • DataTable fornece atributos para modificar seus dados de forma fácil.

Cabeçalho HTML

<html 
   xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html">
</html>

A seguir estão as operações importantes do DataTable no JSF 2.0 -

S.No Tag e descrição
1 Exibir DataTable

Como exibir uma dataTable

2 Adicionar dados

Como adicionar uma nova linha em uma dataTable

3 Editar dados

Como editar uma linha em uma dataTable

4 Apagar dados

Como excluir uma linha em dataTable

5 Usando DataModel

Use DataModel para exibir números de linha em uma dataTable

O JSF fornece aos desenvolvedores um recurso poderoso para definir seus próprios componentes personalizados, que podem ser usados ​​para renderizar conteúdos personalizados.

Definir componente personalizado

Definir um componente personalizado no JSF é um processo de duas etapas.

Degrau Descrição
1a

Crie uma pasta de recursos.

Crie um arquivo xhtml na pasta de recursos com um namespace composto.

1b

Use as tags compostas composto: interface, composto: atributo e composto: implementação, para definir o conteúdo do componente composto. Use cc.attrs em Composite : Implementation para obter a variável definida usando composite: attribute em composite: interface .

Etapa 1a: Criar um componente personalizado: loginComponent.xhtml

Crie uma pasta tutorialspoint na pasta de recursos e crie um arquivo loginComponent.xhtml nela.

Use o namespace composto no cabeçalho html.

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:composite = "http://java.sun.com/jsf/composite">
...
</html>

Etapa 1b: Use Tags compostas: loginComponent.xhtml

A tabela a seguir descreve o uso de tags compostas.

S.No Tag e descrição
1

composite:interface

Declara valores configuráveis ​​a serem usados ​​em composto: implementação.

2

composite:attribute

Os valores de configuração são declarados usando esta tag.

3

composite:implementation

Declara o componente JSF. Pode acessar os valores configuráveis ​​definidos em composite: interface usando a expressão # {cc.attrs.attribute-name}.

<composite:interface>
   <composite:attribute name = "usernameLabel" />
   <composite:attribute name = "usernameValue" />
</composite:interface>

<composite:implementation>
<h:form>
   #{cc.attrs.usernameLabel} : 
   <h:inputText id = "username" value = "#{cc.attrs.usernameValue}" />
</h:form>

Usar componente personalizado

Usar um componente personalizado no JSF é um processo simples.

Degrau Descrição
2a Crie um arquivo xhtml e use o namespace do componente personalizado. O namespace será o http://java.sun.com/jsf/ <folder-name> onde folder-name é a pasta no diretório de recursos que contém o componente personalizado
2b Use o componente personalizado como tags JSF normais

Etapa 2a: use o namespace personalizado: home.xhtml

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:ui = "http://java.sun.com/jsf/facelets">
   xmlns:tp = "http://java.sun.com/jsf/composite/tutorialspoint">

Etapa 2b: usar tag personalizada: home.xhtml e passar valores

<h:form>
   <tp:loginComponent 
      usernameLabel = "Enter User Name: " 
      usernameValue = "#{userData.name}" />
</h:form>

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar o componente personalizado no JSF.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Crie a pasta de recursos em src → pasta principal .
3 Crie a pasta tutorialspoint em src → principal → pasta de recursos .
4 Crie o arquivo loginComponent.xhtml na pasta src → principal → recursos → tutorialspoint .
5 Modifique o arquivo UserData.java conforme explicado abaixo.
6 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
7 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
8 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
9 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

loginComponent.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:composite = "http://java.sun.com/jsf/composite">
   
   <composite:interface>
      <composite:attribute name = "usernameLabel" />
      <composite:attribute name = "usernameValue" />
      <composite:attribute name = "passwordLabel" />
      <composite:attribute name = "passwordValue" />
      <composite:attribute name = "loginButtonLabel" />
      <composite:attribute name = "loginButtonAction" 
         method-signature = "java.lang.String login()" />
   </composite:interface>
   
   <composite:implementation>
      <h:form>
         <h:message for = "loginPanel" style = "color:red;" />
         
         <h:panelGrid columns = "2" id = "loginPanel">
            #{cc.attrs.usernameLabel} : 
            <h:inputText id = "username" value = "#{cc.attrs.usernameValue}" />
            #{cc.attrs.passwordLabel} : 
            <h:inputSecret id = "password" value = "#{cc.attrs.passwordValue}" />
         </h:panelGrid>
         
         <h:commandButton action = "#{cc.attrs.loginButtonAction}" 
            value = "#{cc.attrs.loginButtonLabel}"/>
      </h:form>
   </composite:implementation>
</html>

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private String name;
   private String password;
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }
   
   public String getPassword() {
      return password;
   }
   
   public void setPassword(String password) {
      this.password = password;
   }	
   
   public String login() {
      return "result";
   }	
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:tp = "http://java.sun.com/jsf/composite/tutorialspoint">
   
   <h:head>
      <title>JSF tutorial</title>		     
   </h:head>
   
   <h:body> 
      <h2>Custom Component Example</h2>
      
      <h:form>
      <tp:loginComponent 
         usernameLabel = "Enter User Name: " 
         usernameValue = "#{userData.name}" 
         passwordLabel = "Enter Password: " 
         passwordValue = "#{userData.password}"
         loginButtonLabel = "Login" 
         loginButtonAction = "#{userData.login}" />
      </h:form>
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

AJAX significa Asynchronous JavaScript and Xml.

Ajax é uma técnica para usar HTTPXMLObject de JavaScript para enviar dados ao servidor e receber dados do servidor de forma assíncrona. Assim, usando a técnica Ajax, o código javascript troca dados com o servidor, atualiza partes da página da web sem recarregar a página inteira.

JSF fornece excelente suporte para fazer chamadas ajax. Ele fornece a tag f: ajax para lidar com chamadas ajax.

Tag JSF

<f:ajax execute = "input-component-name" render = "output-component-name" />

Atributos de tag

S.No Atributo e descrição
1

disabled

Se verdadeiro, o comportamento do Ajax será aplicado a qualquer componente pai ou filho. Se for falso, o comportamento do Ajax será desabilitado.

2

Event

O evento que invocará solicitações Ajax, por exemplo, "clicar", "alterar", "desfocar", "pressionar a tecla" etc.

3

Execute

Uma lista de IDs separados por espaço para componentes que devem ser incluídos na solicitação Ajax.

4

Immediate

Se "true", os eventos de comportamento gerados a partir desse comportamento são transmitidos durante a fase Aplicar valores de solicitação. Caso contrário, os eventos serão transmitidos durante a fase de Invocação de Aplicativos.

5

Listener

Uma expressão EL para um método em um bean de apoio a ser chamado durante a solicitação Ajax.

6

Onerror

O nome de uma função de retorno de chamada JavaScript que será chamada se houver um erro durante a solicitação Ajax.

7

Onevent

O nome de uma função de retorno de chamada JavaScript que será chamada para manipular eventos de IU.

8

Render

Uma lista de IDs separados por espaço para componentes que serão atualizados após uma solicitação Ajax.

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar o componente personalizado no JSF.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Modifique o arquivo UserData.java conforme explicado abaixo.
3 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
4 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
5 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
6 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private String name;
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }

   public String getWelcomeMessage() {
      return "Hello " + name;
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:tp = "http://java.sun.com/jsf/composite/tutorialspoint">
   
   <h:head>
      <title>JSF tutorial</title>
   </h:head>
   
   <h:body>
      <h2>Ajax Example</h2>
      
      <h:form>
         <h:inputText id = "inputName" value = "#{userData.name}"></h:inputText>
         <h:commandButton value = "Show Message">
            <f:ajax execute = "inputName" render = "outputMessage" />
         </h:commandButton>
         <h2><h:outputText id = "outputMessage"
            value = "#{userData.welcomeMessage != null ?
            userData.welcomeMessage : ''}"
         /></h2>
      </h:form>
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

Digite o nome e pressione o botão Mostrar mensagem. Você verá o seguinte resultado sem atualização de página / envio de formulário.

Quando um usuário clica em um botão ou link JSF ou altera qualquer valor no campo de texto, o componente de IU do JSF dispara um evento, que será tratado pelo código do aplicativo. Para manipular tal evento, um manipulador de eventos deve ser registrado no código do aplicativo ou bean gerenciado.

Quando um componente de UI verifica se um evento de usuário ocorreu, ele cria uma instância da classe de evento correspondente e a adiciona a uma lista de eventos. Em seguida, Component dispara o evento, ou seja, verifica a lista de ouvintes para aquele evento e chama o método de notificação de evento em cada ouvinte ou manipulador.

O JSF também fornece manipuladores de eventos no nível do sistema, que podem ser usados ​​para executar algumas tarefas quando o aplicativo é iniciado ou interrompido.

A seguir estão alguns manipuladores de eventos importantes no JSF 2.0 -

S.No Manipuladores de eventos e descrição
1 valueChangeListener

Os eventos de alteração de valor são disparados quando o usuário faz alterações nos componentes de entrada.

2 actionListener

Os eventos de ação são disparados quando o usuário clica em um botão ou componente de link.

3 Eventos de aplicativos

Eventos disparados durante o ciclo de vida do JSF: PostConstructApplicationEvent, PreDestroyApplicationEvent, PreRenderViewEvent.

Neste artigo, vamos demonstrar como integrar o banco de dados em JSF usando JDBC.

A seguir estão os requisitos do banco de dados para executar este exemplo.

S.No Software e descrição
1 PostgreSQL 9.1

Banco de dados de código aberto e leve

2 Driver PostgreSQL JDBC4

Driver JDBC para PostgreSQL 9.1 e JDK 1.5 ou superior

Coloque o jar do driver JDBC4 do PostgreSQL no diretório lib do servidor web tomcat.

Comandos de banco de dados SQL

create user user1;
create database testdb with owner = user1;

CREATE TABLE IF NOT EXISTS authors (
    id int PRIMARY KEY, 
    name VARCHAR(25)
);

INSERT INTO authors(id, name) VALUES(1, 'Rob Bal');
INSERT INTO authors(id, name) VALUES(2, 'John Carter');
INSERT INTO authors(id, name) VALUES(3, 'Chris London');
INSERT INTO authors(id, name) VALUES(4, 'Truman De Bal');
INSERT INTO authors(id, name) VALUES(5, 'Emile Capote');
INSERT INTO authors(id, name) VALUES(7, 'Breech Jabber');
INSERT INTO authors(id, name) VALUES(8, 'Bob Carter');
INSERT INTO authors(id, name) VALUES(9, 'Nelson Mand');
INSERT INTO authors(id, name) VALUES(10, 'Tennant Mark');

alter user user1 with password 'user1';

grant all on authors to user1;

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar a integração JDBC.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Crie a pasta de recursos em src → pasta principal .
3 Crie a pasta css em src → principal → pasta de recursos .
4 Crie o arquivo styles.css em src → principal → recursos → pasta css .
5 Modifique o arquivo styles.css conforme explicado abaixo.
6 Modifique pom.xml conforme explicado a seguir.
7 Crie Author.java no pacote com.tutorialspoint.test conforme explicado a seguir.
8 Crie UserData.java no pacote com.tutorialspoint.test conforme explicado a seguir.
9 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
10 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
11 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
12 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

styles.css

.authorTable {   
   border-collapse:collapse;
   border-bottom:1px solid #000000;
}

.authorTableHeader {
   text-align:center;
   background:none repeat scroll 0 0 #B5B5B5;
   border-bottom:1px solid #000000;
   border-top:1px solid #000000;
   padding:2px;
}

.authorTableOddRow {
   text-align:center;
   background:none repeat scroll 0 0 #FFFFFFF;	
}

.authorTableEvenRow {
   text-align:center;
   background:none repeat scroll 0 0 #D3D3D3;
}

pom.xml

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
   http://maven.apache.org/maven-v4_0_0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint.test</groupId>
   <artifactId>helloworld</artifactId>
   <packaging>war</packaging>
   <version>1.0-SNAPSHOT</version>
   <name>helloworld Maven Webapp</name>
   <url>http://maven.apache.org</url >
   
   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-api</artifactId>
         <version>2.1.7</version>
      </dependency>
      
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-impl</artifactId>
         <version>2.1.7</version>
      </dependency>
      
      <dependency>
         <groupId>javax.servlet</groupId>
         <artifactId>jstl</artifactId>
         <version>1.2</version>
      </dependency>
      
      <dependency>
        <groupId>postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <version>9.1-901.jdbc4</version>
     </dependency>
   </dependencies>
   
   <build>
      <finalName>helloworld</finalName>
      <plugins>
         <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.3.1</version>
            <configuration>
               <source>1.6</source>
               <target>1.6</target>
            </configuration>
         </plugin>
         
         <plugin>
            <artifactId>maven-resources-plugin</artifactId>
            <version>2.6</version>
            <executions>
               <execution>
                  <id>copy-resources</id>
                  <phase>validate</phase>
                  <goals>
                     <goal>copy-resources</goal>
                  </goals>
                  
                  <configuration>
                     <outputDirectory>${basedir}/target/helloworld/resources
                        </outputDirectory>
                     <resources>          
                        <resource>
                           <directory>src/main/resources</directory>
                           <filtering>true</filtering>
                        </resource>
                     </resources>              
                  </configuration>            
               </execution>
            </executions>
         </plugin>
      
      </plugins>
   </build>
</project>

Author.java

package com.tutorialspoint.test;

public class Author {
   int id;
   String name;
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }
   
   public int getId() {
      return id;
   }
   
   public void setId(int id) {
      this.id = id;
   }
}

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import java.util.ArrayList;
import java.util.List;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.event.ComponentSystemEvent;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;

   public List<Author> getAuthors() {
      ResultSet rs = null;
      PreparedStatement pst = null;
      Connection con = getConnection();
      String stm = "Select * from authors";
      List<Author> records = new ArrayList<Author>();
      
      try {   
         pst = con.prepareStatement(stm);
         pst.execute();
         rs = pst.getResultSet();

         while(rs.next()) {
            Author author = new Author();
            author.setId(rs.getInt(1));
            author.setName(rs.getString(2));
            records.add(author);				
         }
      } catch (SQLException e) {
         e.printStackTrace();
      }
      return records;
   }

   public Connection getConnection() {
      Connection con = null;
      String url = "jdbc:postgresql://localhost/testdb";
      String user = "user1";
      String password = "user1";
      
      try {
         con = DriverManager.getConnection(url, user, password);
         System.out.println("Connection completed.");
      } catch (SQLException ex) {
         System.out.println(ex.getMessage());
      }
      
      finally {
      }
      return con;
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:f = "http://java.sun.com/jsf/core"    
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:head>
      <title>JSF Tutorial!</title>
      <h:outputStylesheet library = "css" name = "styles.css"  /> 
   </h:head>
   
   <h:body>
      <h2>JDBC Integration Example</h2>
      
      <h:dataTable value = "#{userData.authors}" var = "c"
         styleClass = "authorTable"
         headerClass = "authorTableHeader"
         rowClasses = "authorTableOddRow,authorTableEvenRow">
         
         <h:column><f:facet name = "header">Author ID</f:facet>
            #{c.id}
         </h:column>
         
         <h:column><f:facet name = "header">Name</f:facet>
            #{c.name}
         </h:column>
      </h:dataTable>
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

O Spring fornece uma classe especial DelegatingVariableResolver para integrar JSF e Spring de uma maneira contínua.

As etapas a seguir são necessárias para integrar o recurso Spring Dependency Injection (IOC) no JSF.

Etapa 1: Adicionar DelegatingVariableResolver

Adicione uma entrada variable-resolver em faces-config.xml para apontar para a classe spring DelegatingVariableResolver.

<faces-config>
   <application>
   <variable-resolver>
      org.springframework.web.jsf.DelegatingVariableResolver
   </variable-resolver>
   ...
</faces-config>

Etapa 2: adicionar ouvintes de contexto

Adicionar ContextLoaderListener e RequestContextListener listener fornecido pelo spring framework em web.xml.

<web-app>
   ...
   <!-- Add Support for Spring -->
   <listener>
      <listener-class>
         org.springframework.web.context.ContextLoaderListener
      </listener-class>
   </listener>
   
   <listener>
      <listener-class>
         org.springframework.web.context.request.RequestContextListener
      </listener-class>
   </listener>
   ...
</web-app>

Etapa 3: Definir Dependência

Defina bean (s) em applicationContext.xml que será usado como dependência no bean gerenciado.

<beans>
   <bean id = "messageService" 
      class = "com.tutorialspoint.test.MessageServiceImpl">
      <property name = "message" value = "Hello World!" />        
   </bean>
</beans>

Etapa 4: adicionar dependência

DelegatingVariableResolverprimeiro delega pesquisas de valor para o resolvedor padrão do JSF e, em seguida, para WebApplicationContext do Spring. Isso permite injetar dependências baseadas em spring facilmente nos beans gerenciados por JSF.

Injetamos messageService como dependência baseada em mola aqui.

<faces-config>
   ...
   <managed-bean>
      <managed-bean-name>userData</managed-bean-name>
      <managed-bean-class>com.tutorialspoint.test.UserData</managed-bean-class>
      <managed-bean-scope>request</managed-bean-scope>
      
      <managed-property>
         <property-name>messageService</property-name>
         <value>#{messageService}</value>
      </managed-property>
   </managed-bean> 
</faces-config>

Etapa 5: usar dependência

//jsf managed bean
public class UserData {
   
   //spring managed dependency
   private MessageService messageService;

   public void setMessageService(MessageService messageService) {
      this.messageService = messageService;
   }

   public String getGreetingMessage() {
      return messageService.getGreetingMessage();
   }
}

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar a integração do Spring.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Modifique pom.xml conforme explicado a seguir.
3 Crie faces-config.xml na pasta WEB-INF conforme explicado abaixo.
4 Modifique o web.xml conforme explicado abaixo.
5 Crie applicationContext.xml na pasta WEB-INF conforme explicado abaixo.
6 Crie MessageService.java no pacote com.tutorialspoint.test conforme explicado a seguir.
7 Crie MessageServiceImpl.java no pacote com.tutorialspoint.test conforme explicado a seguir.
8 Crie UserData.java no pacote com.tutorialspoint.test conforme explicado a seguir.
9 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
10 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
11 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
12 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

pom.xml

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
   http://maven.apache.org/maven-v4_0_0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint.test</groupId>
   <artifactId>helloworld</artifactId>
   <packaging>war</packaging>
   <version>1.0-SNAPSHOT</version>
   <name>helloworld Maven Webapp</name>
   <url>http://maven.apache.org</url>
   
   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
      </dependency>
      
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-api</artifactId>
         <version>2.1.7</version>
      </dependency>
      
      <dependency>
         <groupId>com.sun.faces</groupId>
         <artifactId>jsf-impl</artifactId>
         <version>2.1.7</version>
      </dependency>
      
      <dependency>
         <groupId>javax.servlet</groupId>
         <artifactId>jstl</artifactId>
         <version>1.2</version>
      </dependency>
      
      <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-core</artifactId>
         <version>3.1.2.RELEASE</version>
      </dependency>
      
      <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-web</artifactId>
         <version>3.1.2.RELEASE</version> 
      </dependency>
   </dependencies>
   
   <build>
      <finalName>helloworld</finalName>
      <plugins>
         <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.3.1</version>
            <configuration>
               <source>1.6</source>
               <target>1.6</target>
            </configuration>
         </plugin>
         
         <plugin>
            <artifactId>maven-resources-plugin</artifactId>
            <version>2.6</version>
            
            <executions>
               <execution>
                  <id>copy-resources</id>
                  <phase>validate</phase>
                  <goals>
                     <goal>copy-resources</goal>
                  </goals>
                  
                  <configuration>
                     <outputDirectory>${basedir}/target/helloworld/resources
                        </outputDirectory>
                     <resources>          
                        <resource>
                           <directory>src/main/resources</directory>
                           <filtering>true</filtering>
                        </resource>
                     </resources>              
                  </configuration>            
               </execution>
            </executions>
         
         </plugin>
      </plugins>
   </build>
</project>

faces-config.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<faces-config
   xmlns = "http://java.sun.com/xml/ns/javaee"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
   version = "2.0"> 
   
   <application>
      <variable-resolver>
         org.springframework.web.jsf.DelegatingVariableResolver
      </variable-resolver>
   </application>
   
   <managed-bean>
      <managed-bean-name>userData</managed-bean-name>
      <managed-bean-class>com.tutorialspoint.test.UserData</managed-bean-class>
      <managed-bean-scope>request</managed-bean-scope>
      <managed-property>
         <property-name>messageService</property-name>
         <value>#{messageService}</value>
      </managed-property>
   </managed-bean> 
</faces-config>

web.xml

<!DOCTYPE web-app PUBLIC
   "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
   "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
   <display-name>Archetype Created Web Application</display-name>

   <context-param>
      <param-name>javax.faces.PROJECT_STAGE</param-name>
      <param-value>Development</param-value>
   </context-param>	
   
   <!-- Add Support for Spring -->
   <listener> 
      <listener-class>
         org.springframework.web.context.ContextLoaderListener
      </listener-class>
   </listener>
   
   <listener>
      <listener-class>
         org.springframework.web.context.request.RequestContextListener
      </listener-class>
   </listener>
   
   <servlet>
      <servlet-name>Faces Servlet</servlet-name>
      <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
   </servlet>
   
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.jsf</url-pattern>
   </servlet-mapping>
</web-app>

applicationContext.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN 2.0//EN" 
   "http://www.springframework.org/dtd/spring-beans-2.0.dtd">

<beans>
   <bean id = "messageService" 
      class = "com.tutorialspoint.test.MessageServiceImpl">
      <property name = "message" value = "Hello World!" />        
   </bean>
</beans>

MessageService.java

package com.tutorialspoint.test;

public interface MessageService {
   String getGreetingMessage();
}

MessageServiceImpl.java

package com.tutorialspoint.test;

public class MessageServiceImpl implements MessageService {
   private String message;
   
   public String getGreetingMessage() {
      return message;
   }
   
   public String getMessage() {
      return message;
   }
   public void setMessage(String message) {
      this.message = message;
   }
}

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;

public class UserData implements Serializable {

   private static final long serialVersionUID = 1L;
	private MessageService messageService;

   public MessageService getMessageService() {
      return messageService;
   }

   public void setMessageService(MessageService messageService) {
      this.messageService = messageService;
   }

   public String getGreetingMessage() {
      return messageService.getGreetingMessage();
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:f = "http://java.sun.com/jsf/core"    
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:head>
      <title>JSF Tutorial!</title>
   </h:head>
   
   <h:body>
      <h2>Spring Integration Example</h2>
      #{userData.greetingMessage}
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

JSF fornece uma linguagem de expressão rica. Podemos escrever operações normais usando#{operation-expression}notação. A seguir estão algumas das vantagens das linguagens de expressão JSF.

  • Pode referenciar propriedades de bean onde o bean pode ser um objeto armazenado no escopo de solicitação, sessão ou aplicativo ou é um bean gerenciado.

  • Fornece acesso fácil aos elementos de uma coleção que pode ser uma lista, um mapa ou uma matriz.

  • Fornece acesso fácil a objetos predefinidos, como uma solicitação.

  • Operações aritméticas, lógicas e relacionais podem ser feitas usando a linguagem de expressão.

  • Conversão automática de tipo.

  • Mostra os valores ausentes como strings vazias em vez de NullPointerException.

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar a linguagem de expressão.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Modifique UserData.java no pacote com.tutorialspoint.test conforme explicado abaixo.
3 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
4 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
5 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
6 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;
import java.util.Date;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private Date createTime = new Date();
   private String message = "Hello World!";

   public Date getCreateTime() {
      return(createTime);
   }
   
   public String getMessage() {
      return(message);
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:f = "http://java.sun.com/jsf/core"    
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:head>
      <title>JSF Tutorial!</title>
   </h:head>
   
   <h:body>
      <h2>Expression Language Example</h2>
      Creation time: 
      <h:outputText value = "#{userData.createTime}"/>
      <br/><br/>
      Message: 
      <h:outputText value = "#{userData.message}"/>
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

A internacionalização é uma técnica na qual mensagens de status, rótulos de componentes GUI, moeda e data não são codificados no programa. Em vez disso, eles são armazenados fora do código-fonte em pacotes de recursos e recuperados dinamicamente. O JSF fornece uma maneira muito conveniente de lidar com o pacote de recursos.

As etapas a seguir são necessárias para internalizar um aplicativo JSF.

Etapa 1: definir os arquivos de propriedades

Crie o arquivo de propriedades para cada local. O nome deve estar no formato <file-name> _ <locale> .properties.

O local padrão pode ser omitido no nome do arquivo.

messages.properties

greeting = Hello World!

messages_fr.properties

greeting = Bonjour tout le monde!

Etapa 2: atualize faces-config.xml

faces-config.xml

<application>
   <locale-config>
      <default-locale>en</default-locale>
      <supported-locale>fr</supported-locale>
   </locale-config>
   
   <resource-bundle>
      <base-name>com.tutorialspoint.messages</base-name>
      <var>msg</var>
   </resource-bundle>
</application>

Etapa 3: usar var do pacote de recursos

home.xhtml

<h:outputText value = "#{msg['greeting']}" />

Aplicação de exemplo

Vamos criar um aplicativo JSF de teste para testar a internacionalização em JSF.

Degrau Descrição
1 Crie um projeto com o nome helloworld sob um pacote com.tutorialspoint.test conforme explicado no capítulo JSF - Primeira Aplicação .
2 Crie a pasta de recursos na pasta src → mai .
3 Crie a pasta com sob src → principal → pasta de recursos .
4 Crie a pasta tutorialspoint na pasta src → principal → recursos → com .
5 Crie o arquivo messages.properties na pasta src → principal → recursos → com → pasta tutorialspoint . Modifique-o conforme explicado abaixo.
6 Crie o arquivo messages_fr.properties sob a pasta src → principal → recursos → com → tutorialspoint . Modifique-o conforme explicado abaixo.
7 Crie faces-config.xml em WEB-INFf mais antigo conforme explicado abaixo.
8 Crie UserData.java no pacote com.tutorialspoint.test conforme explicado a seguir.
9 Modifique home.xhtml conforme explicado abaixo. Mantenha o resto dos arquivos inalterados.
10 Compile e execute o aplicativo para garantir que a lógica de negócios esteja funcionando de acordo com os requisitos.
11 Por fim, construa o aplicativo na forma de um arquivo war e implante-o no servidor da Web Apache Tomcat.
12 Inicie seu aplicativo da web usando o URL apropriado, conforme explicado abaixo na última etapa.

messages.properties

greeting = Hello World!

messages_fr.properties

greeting = Bonjour tout le monde!

faces-config.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<faces-config
   xmlns = "http://java.sun.com/xml/ns/javaee"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
   version = "2.0">
   
   <application>
      <locale-config>
         <default-locale>en</default-locale>
         <supported-locale>fr</supported-locale>
      </locale-config>
      
      <resource-bundle>
         <base-name>com.tutorialspoint.messages</base-name>
         <var>msg</var>
      </resource-bundle>
   </application>
</faces-config>

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;
import java.util.LinkedHashMap;
import java.util.Locale;
import java.util.Map;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;
import javax.faces.event.ValueChangeEvent;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private String locale;

   private static Map<String,Object> countries;
      static {
      
      countries = new LinkedHashMap<String,Object>();
      countries.put("English", Locale.ENGLISH);
      countries.put("French", Locale.FRENCH);
   }

   public Map<String, Object> getCountries() {
      return countries;
   }

   public String getLocale() {
      return locale;
   }

   public void setLocale(String locale) {
      this.locale = locale;
   }

   //value change event listener
   public void localeChanged(ValueChangeEvent e) {
      String newLocaleValue = e.getNewValue().toString();
      
      for (Map.Entry<String, Object> entry : countries.entrySet()) {
         
         if(entry.getValue().toString().equals(newLocaleValue)) {
            FacesContext.getCurrentInstance()
               .getViewRoot().setLocale((Locale)entry.getValue());         
         }
      }
   }
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core">
   
   <h:head>
      <title>JSF tutorial</title>	 	
   </h:head>
   
   <h:body> 
      <h2>Internalization Language Example</h2>
      
      <h:form>
         <h3><h:outputText value = "#{msg['greeting']}" /></h3>
         
         <h:panelGrid columns = "2"> 
            Language : 
            <h:selectOneMenu value = "#{userData.locale}" onchange = "submit()"
               valueChangeListener = "#{userData.localeChanged}">
               <f:selectItems value = "#{userData.countries}" /> 
            </h:selectOneMenu> 
         </h:panelGrid> 
      
      </h:form>
   </h:body>
</html>

Assim que você estiver pronto com todas as mudanças feitas, vamos compilar e rodar a aplicação como fizemos no capítulo JSF - Primeira Aplicação. Se tudo estiver certo com sua aplicação, isso produzirá o seguinte resultado.

Altere o idioma no menu suspenso. Você verá a seguinte saída.