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
|
2 | Parâmetros Vamos demonstrar como passar parâmetros para um arquivo de modelo usando a seguinte tag
|
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.