Aula Prática Programação Web II

In stock

Pague pelo PIX ou cartão e faça o download agora mesmo.

portfólio unopar anhangueraportfólio unopar anhangueraportfólio unopar anhanguera

Category:

Aula Prática Programação Web II


ROTEIRO DE AULA PRÁTICA

NOME DA DISCIPLINA: PROGRAMAÇÃO WEB

Unidade: U1_ PROGRAMAÇÃO_EM_JSF

Aula: A2_COMPONENTES_VISUAIS_DO_JSF

OBJETIVOS

Definição dos objetivos da aula prática:

Definição dos objetivos da aula prática: Ensinar o aluno a criar um projeto web dinâmico utilizando

conceitos iniciais de JSF na camada de visão, além de estruturar as partes desse projeto segundo

o padrão de arquitetura MVC, tudo isso sendo aplicado à linguagem de programação Java. Após

a criação e estruturação dos arquivos, aplicaremos uma folha de estilo no formulário criado.

SOLUÇÃO DIGITAL:

Eclipse e Wildfly

Ide Eclipse ou correlata que possua configurações para construção de classes seguindo o Java

EE, com configurações para ter servidor de aplicação e utilizar o framework JSF para a camada

de visão. Recomenda-se o uso do servidor wilfly.

  1. Acesse o site oficial: https://eclipseide.org/
  2. Clique em Download:

Público3

  1. Escolha a versão “Eclipse IDE for Enterprise Java and Web Developers” que compatível

com o sistema operacional do seu computador.

  1. Após o download, descompacte o já estará pronto para uso.

PROCEDIMENTOS PRÁTICOS E APLICAÇÕES

Procedimento/Atividade nº 1

CONSTRUINDO UM CONJUNTO DE CLASSES COM O MVC E JSF.

Atividade proposta: Criaremos um projeto baseado em Java EE (Projeto de WEB Dinâmico)

com organização preconizada pelo MVC, para cadastro de faculdades.

Você deve elaborar, pelo menos, uma classe de modelo chamada Faculdade. Essa classe terá

um id (int), nomeCompleto (String) e nomeFantasia (String). Esses dados devem ser obtidos

através de um formulário que contenha esses três elementos para ser digitados pelo usuário.

Esse formulário deve estar presente na página faculdades.xhtml e ela deve obrigatoriamente

utilizar conceitos de JSF que seja compatível com as premissas de utilização de

ManagedBeans. A classe Java FaculdadeMB será a responsável por controlar as requisições

oriundas da camada de visão e passá-las para a camada modelo. As etapas descritas a seguir

foram criadas usando a IDE Eclipse, com o servidor Wildfly.

Procedimentos para a realização da atividade:

Para iniciar a atividade, vamos criar um projeto web dinâmico:

Público4

Figura 1 – Criando um Dynamic Web Project

Vamos dar o nome “Faculdade” ao projeto e colocar as configurações conforme a Figura 7. Caso

seu “Target runtime” esteja vazio como na Figura 2 então clique em “New Runtime…”, então uma

janela abrirá, procure por “WildFly” da mesma forma que a Figura 3, selecione “JBoss AS, WildFly

& EAP Server Tools” e clique em next, prossiga com a instalação até a conclusão, e no final, aceite

os termos. Atenção, mesmo após o aceite dos termos o download e a instalação ainda podem

estar ocorrendo, cheque no canto inferior esquerdo (Figura 4) e logo após a finalização o Eclipse

precisará ser reiniciado, então repita o processo de criação do projeto, caso ainda não tenha o

“Target runtime” clique novamente em “New Runtime…” e procure por “WildFly” (Figura 5),

então selecione “WildFly 10.x Runtime” e clique em next, na próxima clique em “Download and

install runtime…”, vamos utilizar a versão, selecione ela e clique em next, prossiga com a

instalação até a finalização, agora podemos prosseguir com a configuração do projeto.

Figura 2 – Configurando runtime

Público5

Figura 3 – Instalando WildFly

Figura 4 – Processo de download e instalação

Público6

Figura 5 – Seleção Runtime WildFly 10

Figura 6 – Instalação WildFly 10

Público7

Figura 7 – Configurações para criação do projeto

Para criação do formulário, clique com o botão direito sobre o projeto e escolha New >> HTML

File. Dê o nome para o arquivo de faculdades.xhtml e clique em finish. Crie os campos necessários

usando os recursos JSF, conforme código na Figura 8.

Figura 8 – Código para criação do formulário faculdade.xhtml o

Público8

Criada a interface para a tela de cadastro, o próximo passo é criar o pacote “model” e dentro do

pacote criar a classe “Faculdade”, com o código da Figura 9.

Figura 9 – Classe Faculdade

O próximo passo consiste em criar uma classe especial, uma Managed Bean, para fazer o

controle da comunicação entre a camada de visão e a camada modelo. Para isso, no

projeto crie um pacote chamado “control” e dentro do pacote uma nova classe Java

chamada “FaculdadeMB”, com o código da Figura 10.

Público9

Figura 10 – Classe FaculdadeMB

O próximo passo é configurar o arquivo faces-config.xml, que se encontra dentro da pasta

webapp > WEB-INF, clique duas vezes para abrir, caso de primeira não consiga ver o código, no

menu inerior dessa janela clique em “source”. Com o código da Figura 11, adicione as tags das

linhas 8 a 10.

Público10

Figura 11 – Classe FaculdadeMB

Para testar, clique com o botão direito no arquivo faculdades.xhtml e selecione Run as > Run on

Server. Caso uma janela se abra pedindo para selecionar o server, procure por “WildFly”,

selecione “WildFly 10.x” e clique em next (Figura 12), prossiga até finalizar.

Público11

Figura 12 – Selecionar server

Caso de o erro 404 ao rodar o server, siga os seguintes passos:

  1. No Eclipse, vá em:
  2. Project → Properties → Java Compiler
  3. Marque “Enable project specific settings”.
  4. Em Compiler compliance level, selecione 1.8.
  5. Vá em Project → Clean… e limpe/recompile o projeto.
  6. Pare e reinicie o WildFly.

Se todos os códigos foram feitos corretamente, o resultado após preencher e clicar no botão

submit, deverá ser similar ao da Figura 13.

Público12

Figura 12 – Resultado esperado até o momento

Observe o caminho:

Localhost:8080/Faculdade/faces/faculdade.xhtml

A tag <url-pattern> no arquivo web.xml é quem especifica o mapeamento do JSF, veja como está

para esse projeto. Na linha 13 /faces/* implica diretamente no caminho.

Agora passaremos para a finalização do projeto criando o arquivo de estilos. Dando continuidade

crie uma nova pasta, dentro de “webapp”, chamada “resources”. Dentro dessa nova pasta, crie

uma nova, chamada “css”. Quando construímos essa estrutura de pastas, basta adicionar a

seguinte diretriz para que o arquivo xhtml aplique as regras do CSS:

<h:outputStylesheet library=”css” name=”arquivo.css” />

Onde arquivo.css é o nome que dará ao arquivo de folha de estilo.

Vamos criar, dentro da pasta css o arquivo estilo1.css com o seguinte código:

Público13

Pare a execução do servidor, e execute novamente. Veja se o resultado é similar ao da Figura 13.

Figura 13 – Resultado da atividade

Avaliando os resultados:

Ao final da aula, deverá ser entregue um projeto web chamado Faculdade, com uma interface

gráfica, uma classe modelo e uma classe de controle. O sistema deverá estar funcionando.

Utilize esta tabela para organizar os passos realizados e adicionar capturas de tela:

Estrutura do Projeto Criada [Insira o Print]

Arquivo faculdades.xhtml [Insira o Print]

Arquivo Faculdade.java [Insira o Print]

Arquivo FaculdadeMB.java [Insira o Print]

Arquivo estilo1.css [Insira o Print]

Resultado Testado [Insira o Print]

Público14

Checklist:

✓ Estrutura do projeto criada corretamente;

✓ Arquivo xhtml criado;

✓ Classe modelo para o objeto Faculdade;

✓ Arquivos organizados nos devidos pacotes;

✓ ManagedBean criado;

✓ Configuração do arquivo faces-config.xml

✓ Projeto executando em um browser

✓ Pasta “resources” criada dentro de “webapp”

✓ Pasta “css” criada dentro de “resources”

✓ Arquivo css chamado estilo1.css criado dentro da pasta css

✓ Arquivo estilo1.css anexado no arquivo xhtml através da referência:

 <h:outputStylesheet library=”css” name=”estilo1.css” />

RESULTADOS

Resultados do experimento:

O arquivo deverá conter:

  • Capa
  • Folha de rosto com os dados da disciplina e do aluno
  • Métodos: Explique as técnicas que utilizou
  • Resultado:

 Captura de tela da página WEB.

 Captura de tela da estrutura do projeto.

  • Evidências (códigos):

 faculdades.xhtml

 Faculdade.java

 FaculdadeMB.java

 estilo1.css

Resultados de Aprendizagem:

Após concluir esta atividade, você terá aprendido:

  • Criar um projeto web dinâmico em Java utilizando o servidor de aplicações WildFly.
  • Estruturar uma aplicação seguindo o padrão MVC (Model–View–Controller).
  • Desenvolver páginas de interface utilizando JSF (JavaServer Faces) e componentes

XHTML.

  • Implementar Managed Beans para comunicação entre a camada de visão e a camada de

modelo.

Público15

  • Aplicar estilos personalizados em páginas JSF utilizando folhas de estilo (CSS) e a pasta

de recursos padrão do framework.

Público16

ROTEIRO DE AULA PRÁTICA

NOME DA DISCIPLINA: PROGRAMAÇÃO WEB

Unidade: U2_DESENVOLVIMENTO_DE_APLICAÇÕES_EM_JSF_COM_PERSISTÊNCIA

Aula: A2_FRAMEWORK_HIBERNATE

OBJETIVOS

Definição dos objetivos da aula prática:

Nessa aula o objetivo é criar um sistema de agenda fazendo a persistência dos dados usando o

framework Hibernate.

Para isso o sistema será dividido em duas partes:

  • Na primeira deverão ser criados os arquivos de configuração com o banco, bem como a

transação de inserção de dados.

  • Na segunda, serão criados os arquivos necessários à interação do usuário com o sistema,

ou seja, a Managed Bean e o arquivo.xhtml.

SOLUÇÃO DIGITAL:

Eclipse, Wildfly e XAMPP

Ide Eclipse ou correlata que possua configurações para construção de classes seguindo o Java

EE, com configurações para ter servidor de aplicação e utilizar o framework JSF para a camada

de visão. Recomenda-se o uso do servidor wilfly.

  1. Acesse o site oficial: https://eclipseide.org/
  2. Clique em Download:

Público17

  1. Escolha a versão “Eclipse IDE for Enterprise Java and Web Developers” que compatível

com o sistema operacional do seu computador.

  1. Após o download, descompacte o já estará pronto para uso.

PROCEDIMENTOS PRÁTICOS E APLICAÇÕES

Procedimento/Atividade nº 1

DESENVOLVIMENTO DE APLICAÇÃO WEB COM JSF E HIBERNATE – AGENDA DE

CONTATOS.

Atividade proposta: Criaremos um projeto baseado em Java EE (Projeto Web Dinâmico),

organizado segundo o padrão MVC, para o cadastro de contatos.

Você deve elaborar, pelo menos, uma classe de modelo chamada Contato, contendo os atributos

id (Long), nome (String), telefone (String) e email (String). Esses dados serão obtidos por meio de

um formulário presente na página Contato.xhtml, na qual o usuário poderá cadastrar, listar, alterar

e excluir registros.

Público18

A página deve utilizar os componentes e tags do JSF, de forma compatível com as premissas de

utilização de ManagedBeans. A classe Java ContatoMB será responsável por controlar as

requisições oriundas da camada de visão e encaminhá-las à camada de persistência.

A persistência dos dados deve ser implementada por meio da API JPA, com o provedor

Hibernate, realizando a integração com o banco de dados MySQL. A configuração do acesso ao

banco será feita no arquivo persistence.xml, e as operações de CRUD serão estruturadas nas

classes DAO e CRUD, utilizando EntityManager para gerenciar as transações.

As etapas descritas a seguir foram desenvolvidas utilizando a IDE Eclipse e o servidor WildFly,

em conjunto com o XAMPP (phpMyAdmin) para gerenciamento do banco de dados.

Procedimentos para a realização da atividade:

  1. Usando o Xampp (ou outro SGBD), crie um banco de dados chamado “agenda”.
  2. Faça o download do conector MySql pelo link:
  3. https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.11/mysqlconnector-java-8.0.11.jar
  4. Faça o download do Hibernate, os links para download das libs:
  5. https://repo1.maven.org/maven2/antlr/antlr/2.7.7/antlr-2.7.7.jar
  6. https://repo1.maven.org/maven2/com/fasterxml/classmate/1.3.0/classmate-1.3.0.jar
  7. https://repo1.maven.org/maven2/dom4j/dom4j/1.6.1/dom4j-1.6.1.jar
  8. https://repo1.maven.org/maven2/org/hibernate/common/hibernate-commonsannotations/5.0.1.Final/hibernate-commons-annotations-5.0.1.Final.jar
  9. https://repo1.maven.org/maven2/org/hibernate/hibernatecore/5.2.17.Final/hibernate-core-5.2.17.Final.jar
  10. https://repo1.maven.org/maven2/org/hibernate/hibernateentitymanager/5.0.7.Final/hibernate-entitymanager-5.0.7.Final.jar
  11. https://repo1.maven.org/maven2/org/javassist/javassist/3.18.1-GA/javassist-3.18.1-

GA.jar

  1. https://repo1.maven.org/maven2/org/jboss/logging/jboss-logging/3.3.0.Final/jbosslogging-3.3.0.Final.jar
  2. Crie um projeto Dynamic Web com p nome “Agenda” (Figura 1).
  3. Dentro da pasta webapp > WEB-INF > lib, coloque tanto o conector MySql, quanto os

arquivos do Hibernate que você realizou o download nos passos 2 e 3.

  1. Clique com o botão direito no nome do projeto, selecione “Properties” e depois Java Build

Path > aba Libraries. Clique em Add Jars e selecione a pasta lib que você copiou os

arquivos no passo 6 (Figura 2).

  1. Ajustar o compilador

Público19

  1. Clique com o botão direito no projeto Agenda → Properties
  2. Vá em Java Compiler
  3. Marque Enable project specific settings
  4. Em Compiler compliance level, selecione 1.8
  5. Clique em Apply and Close
  6. Ajustar o “Project Facet”
  7. Clique novamente com o botão direito no projeto → Properties
  8. Vá em Project Facets
  9. Procure a linha Java
  10. Altere a Version para 1.8
  11. Se estiver cinza:
  12. Clique no link “Further configuration available…”
  13. No campo “Runtimes”, marque o WildFly 10 Runtime (ou configure

se ainda não existir)

  1. Clique em OK e volte para 1.8
  2. Clique em Apply and Close

Público20

Figura 1 – Criando o projeto

Figura 2 – Adicionando libs

  1. Dentro da pasta webpp> META-INF crie o arquivo persistence.xml

Público21

<?xml version=”1.0″ encoding=”UTF-8″?>

<persistence xmlns=”http://xmlns.jcp.org/xml/ns/persistence”

xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”

xsi:schemaLocation=”http://xmlns.jcp.org/xml/ns/persistence

http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd”

version=”2.1″>

<persistence-unit name=”agendaPersist” transaction-type=”RESOURCE_LOCAL”>

<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>

<class>model.Contato</class>

<properties>

<property name=”javax.persistence.jdbc.url”

value=”jdbc:mysql://localhost:3306/agenda?serverTimezone=UTC”/>

<property name=”javax.persistence.jdbc.user” value=”root”/>

<property name=”javax.persistence.jdbc.password” value=””/>

<property name=”javax.persistence.jdbc.driver” value=”com.mysql.cj.jdbc.Driver”/>

<property name=”hibernate.show_sql” value=”true”/>

<property name=”hibernate.format_sql” value=”true”/>

<property name=”hibernate.dialect” value=”org.hibernate.dialect.MySQL5Dialect”/>

<property name=”hibernate.hbm2ddl.auto” value=”create”/>

</properties>

</persistence-unit>

</persistence>

  1. Crie um pacote chamado “model” dentro da pasta raiz “src” e crie a classe “Contato”, com

o seguinte código:

package model;

import javax.persistence.*;

@Entity

@Table(name = “Contato”)

public class Contato {

@Id

@GeneratedValue(strategy = GenerationType.IDENTITY)

@Column

private int id;

@Column

private String nome;

Público22

@Column

private String sobrenome;

@Column

private String telefone;

@Column

private String email;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getNome() {

return nome;

}

public void setNome(String nome) {

this.nome = nome;

}

public String getSobrenome() {

return sobrenome;

}

public void setSobrenome(String sobrenome) {

this.sobrenome = sobrenome;

}

public String getTelefone() {

return telefone;

}

public void setTelefone(String telefone) {

this.telefone = telefone;

}

public String getEmail() {

Público23

return email;

}

public void setEmail(String email) {

this.email = email;

}

}

  1. Dentro da pasta model crie a classe DAO, para fazer a conexão com o banco

package model;

import javax.persistence.*;

public class DAO {

private static final EntityManagerFactory emFactory;

static {

emFactory = Persistence.createEntityManagerFactory(“agendaPersist”);

}

public static EntityManager getEntityManager() {

return emFactory.createEntityManager();

}

public static void fecharFactory() {

emFactory.close();

}

}

  1. Dentro da pasta model crie agora a classe CRUD.

package model;

import javax.persistence.*;

public class CRUD {

public static void inserir(Contato c1) {

try {

EntityManager entityManager = DAO.getEntityManager();

Público24

entityManager.getTransaction().begin();

entityManager.persist(c1);

entityManager.getTransaction().commit();

entityManager.close();

System.out.println(“conectado Salvo!”);

} catch(Exception ex) {

ex.printStackTrace();

}

}

}

Nesse momento, fique à vontade caso queira implementar as demais transações com o banco, elas estão

disponíveis no texto principal da seção 2.3.

Agora vamos criar os componentes necessários para a interação do usuário com o sistema.

  1. Crie o pacote “controller” dentro da pasta raiz “src” e dentro dele crie a classe ContatoMB com o

seguinte código:

package controller;

import javax.faces.bean.ManagedBean;

import model.*;

@ManagedBean

public class ContatoMB {

public ContatoMB() {

}

private Contato c = new Contato();

public String getId() {

return String.valueOf(c.getId());

}

public void setId(String id) {

c.setId(Integer.parseInt(id));

}

public String getNome() {

return c.getNome();

}

Público25

public void setNome(String nome) {

c.setNome(nome);

}

public String getSobrenome() {

return c.getSobrenome();

}

public void setSobrenome(String sobrenome) {

c.setSobrenome(sobrenome);

}

public String getTelefone() {

return c.getTelefone();

}

public void setTelefone(String telefone) {

c.setTelefone(telefone);

}

public void setEmail(String email) {

c.setEmail(email);

}

public String getEmail() {

return c.getEmail();

}

public void salvar() {

try {

CRUD.inserir(c);

} catch(Exception ex){

ex.printStackTrace();

}

}

}

  1. Configure arquivo faces-config.xml na pasta webapp>WEB-INF, deixando com o seguinte

código:

<?xml version=”1.0″ encoding=”UTF-8″?>

<faces-config

xmlns=”http://xmlns.jcp.org/xml/ns/javaee”

xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”

Público26

xsi:schemaLocation=”http://xmlns.jcp.org/xml/ns/javaee

http://xmlns.jcp.org/xml/ns/javaee/web-facesconfig_2_2.xsd”

version=”2.2″>

<managed-bean>

<managed-bean-name>contatoMB</managed-bean-name>

<managed-bean-class>controller.ContatoMB</managed-bean-class>

<managed-bean-scope>request</managed-bean-scope>

</managed-bean>

</faces-config>

  1. Por fim, crie o arquivo Contato.xhtml dentro da pasta webapp, com o seguinte código:

<!DOCTYPE html>

<html xmlns=”http://www.w3.org/1999/xhtml”

xmlns:h=”http://xmlns.jcp.org/jsf/html”>

<h:head>

<meta charset=”UTF-8″ />

<title>Cadastro de Contatos</title>

</h:head>

<h:body>

<h2>Novo Contato</h2>

<h:form>

<p>Nome:

<h:inputText value=”#{contatoMB.nome}”/>

</p>

<p>Sobrenome:

<h:inputText value=”#{contatoMB.sobrenome}”/>

</p>

<p>Telefone:

<h:inputText value=”#{contatoMB.telefone}”/>

</p>

<p>Email:

<h:inputText value=”#{contatoMB.email}”/>

</p>

<h:commandButton value=”Salvar” action=”#{contatoMB.salvar}” />

</h:form>

<p>Cadastro confirmado:

Código: #{contatoMB.id}

Nome: #{contatoMB.nome} #{contatoMB.sobrenome}

Público27

</p>

</h:body>

</html>

Com a criação dos 6 arquivos de códigos descritos nas duas atividades, juntamente com as

configurações que foram realizadas, o projeto “Agenda” está pronto para ser executado e persistir

dados.

Checklist:

✓ Criar o Banco de dados Usuários no MySQL;

✓ Criação da estrutura do projeto no Eclipse;

✓ Criação o arquivo de persistência;

✓ Criação da classe Contato.java;

✓ Criação da classe DAO.java;

✓ Criação da classe CRUD.java;

✓ Criação da classe Managed Bean chamada “ContatoMB”;

✓ Configuração do arquivo faces-config.xml;

✓ Criação da interface gráfica em um arquivo xhtml.

RESULTADOS

Resultados do experimento:

O arquivo deverá conter:

  • Capa
  • Folha de rosto com os dados da disciplina e do aluno
  • Métodos: Explique as técnicas que utilizou
  • Resultado:

 Captura de tela da raiz do projeto;

 Captura de tela da página Contato funcionando;

 Captura de tela da tabela do banco de dados com pelo menos 5 dados inseridos.

  • Evidências (códigos):

 Persistence.xml

 Contato.java

 DAO.java

 CRUD.java

 ContatoMB.java

Público28

 Contato.xhtml

Resultados de Aprendizagem:

Após concluir esta atividade, você terá aprendido:

  • Criação e configuração de um projeto Java EE (Web Dinâmico) estruturado segundo o

padrão MVC.

  • Implementação de um CRUD (Create, Read, Update, Delete) utilizando JSF como camada

de visão.

  • Mapeamento de entidades e persistência de dados com JPA/Hibernate integrando com o

banco de dados MySQL.

  • Configuração e utilização do arquivo persistence.xml para definir o provedor de

persistência e os parâmetros de conexão.

  • Manipulação de dados por meio da API EntityManager, aplicando boas práticas de

transações e controle de exceções.

  • Integração entre as camadas View, Controller e Model, garantindo comunicação eficiente

entre os componentes do sistema.

Público29

ROTEIRO DE AULA PRÁTICA

NOME DA DISCIPLINA: PROGRAMAÇÃO WEB II

Unidade: U3_DESENVOLVIMENTO_DE_APLICAÇÕES_EM_JSF_E_SUAS_EXTENSÕES

Aula: A3_FRAMEWORK_TOMAHAWK_HIGHFACES_E_BOOFACES

OBJETIVOS

Definição dos objetivos da aula prática:

  • Compreender o papel dos frameworks Tomahawk, HighFaces e BootsFaces no

ecossistema JSF, reconhecendo como eles ampliam os recursos visuais e funcionais das

aplicações web.

  • Explorar a integração do BootsFaces com o JSF, aplicando componentes visuais

baseados em Bootstrap para criar interfaces modernas, responsivas e de fácil

manutenção.

  • Desenvolver uma aplicação prática utilizando BootsFaces, aplicando seus principais

componentes (como <b:form>, <b:inputText>, <b:commandButton>, <b:dataTable>, entre

outros) em conjunto com ManagedBeans e a arquitetura MVC.

SOLUÇÃO DIGITAL:

Eclipse e BootsFaces

Ide Eclipse ou correlata que possua configurações para construção de classes seguindo o Java

EE, com configurações para ter servidor de aplicação e utilizar o framework JSF para a camada

de visão. Recomenda-se o uso do servidor wilfly.

  1. Acesse o site oficial: https://eclipseide.org/
  2. Clique em Download:

Público30

  1. Escolha a versão “Eclipse IDE for Enterprise Java and Web Developers” que compatível

com o sistema operacional do seu computador.

  1. Após o download, descompacte o já estará pronto para uso.

PROCEDIMENTOS PRÁTICOS E APLICAÇÕES

Procedimento/Atividade nº 1

DESENVOLVIMENTO DE INTERFACES JSF COM BOOTSFACES E DATATABLE

Atividade proposta:

Criaremos um projeto baseado em Java EE (Projeto Web Dinâmico) utilizando o framework JSF

e a biblioteca BootsFaces, com o objetivo de desenvolver uma interface moderna e responsiva

para listagem de veículos.

Você deverá elaborar uma classe de modelo chamada Veículo, contendo os atributos id

(Integer), modelo (String), fabricante (String), ano (int) e valor (double). Esses dados serão

manipulados por meio de uma tabela dinâmica na página veiculos.xhtml, utilizando o

componente <b:dataTable> do BootsFaces.

O projeto deve seguir o padrão MVC, utilizando uma classe ManagedBean (VeiculoMB) para

controlar as ações do usuário e repassar os dados para a camada de modelo. A tabela deve

permitir a exibição dos registros cadastrados e aplicar o estilo visual oferecido pelo BootsFaces,

garantindo uma interface limpa e intuitiva.

As etapas descritas a seguir foram desenvolvidas na IDE Eclipse, com o servidor WildFly,

demonstrando a integração entre JSF e BootsFaces na criação de aplicações web modernas e

compatíveis com o padrão Java EE.

Procedimentos para a realização da atividade:

Público31

  1. Crie um novo projeto chamado PraticaBootsFaces, com as configurações da

Figura 1.

Figura 1 – Criando o projeto

  1. Ajustar o compilador

 Clique com o botão direito no projeto Agenda → Properties

 Vá em Java Compiler

 Marque Enable project specific settings

 Em Compiler compliance level, selecione 1.8

 Clique em Apply and Close

  1. Dentro da pasta java raiz “src”, criar um novo pacote chamado model. Dentro

desse pacote criar a classe Carro.java com o seguinte código:

package model;

public class Carro {

private String modelo;

private String marca;

public Carro(String marca, String modelo) {

this.modelo = modelo;

this.marca = marca;

}

public String getModelo() {

return modelo;

}

Público32

public void setModelo(String modelo) {

this.modelo = modelo;

}

public String getMarca() {

return marca;

}

public void setMarca(String marca) {

this.marca = marca;

}

}

  1. Dentro da pasta java raiz “src”, criar um novo pacote chamado control, e dentro

dele criar uma nova classe java chamada CarrosMB.java, com o seguinte código:

package control;

import java.util.ArrayList;

import java.util.List;

import javax.faces.bean.ManagedBean;

import model.Carro;

@ManagedBean

public class CarrosMB {

public CarrosMB() {

carros = new ArrayList<Carro>();

carros.add(new Carro(“Marca 1”, “Modelo 1”));

carros.add(new Carro(“Marca 2”, “Modelo 2”));

carros.add(new Carro(“Marca 3”, “Modelo 3”));

}

private List<Carro> carros;

public List<Carro> getCarros() {

return carros;

}

public void setCarros(List<Carro> carros) {

this.carros = carros;

}

}

  1. Dentro do arquivo faces-config.xml acrescentar a seguinte configuração:

<managed-bean>

<managed-bean-name>carrosMB</managed-bean-name>

<managed-bean-class>control.CarrosMB</managed-bean-class>

<managed-bean-scope>request</managed-bean-scope>

</managed-bean>

Agora vamos criar a interface gráfica para usar os dados da Managed Bean CarrosMB.java.

Acesse o site https://github.com/TheCoder4eu/BootsFacesOSP/releases/download/v1.3.0/BootsFaces-OSP-1.3.0-dist.jar e faça o download do framework

BootsFaces. Descompacte o arquivo e copie o JAR para a pasta lib do projeto. Utilizamos o

arquivo “BootsFaces-OSP-1.3.0-dist”.

Público33

Dentro da pasta webapp crie um arquivo chamado pagina.xhtml, com o respectivo código:

<!DOCTYPE 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:b=”http://bootsfaces.net/ui”>

<h:head>

<title>Aula prática</title>

</h:head>

<h:body>

<h:form>

<b:container fluid=”true”>

<b:jumbotron>

<h2>KLS 2.0</h2>

<p>Programação para web 2 – JSF</p>

<p> <a href=”link” class=”btn btn-lg btn-info”>Veja mais. »</a> </p>

</b:jumbotron>

<b:panel title=”Painel 1″>

<h2>Veículos disponíveis</h2>

<b:dataTable value=”#{carrosMB.carros}” var=”car”>

<b:dataTableColumn value=”#{car.marca}” />

<b:dataTableColumn value=”#{car.modelo}” />

</b:dataTable>

</b:panel>

<b:panel title=”Painel 2″>

<b:inputText placeholder=”Digite seu nome completo” label=”Nome:” />

<b:datepicker label=”Data de nascimento” />

<b:selectOneMenu label=”Possui habilitação”>

<f:selectItem itemValue=”sim” itemLabel=”sim” />

<f:selectItem itemValue=”nao” itemLabel=”não” />

</b:selectOneMenu>

<b:selectMultiMenu label=”Selecione vários”>

<f:selectItem itemValue=”op1″ itemLabel=”Habilitação para moto” />

<f:selectItem itemValue=”op2″ itemLabel=”Habilitação para carro” />

<f:selectItem itemValue=”op2″ itemLabel=”Habilitação para caminhão” />

</b:selectMultiMenu>

</b:panel>

</b:container>

</h:form>

</h:body>

</html>

Se todos os passos foram devidamente seguidos, o resultado será como na Figura 2.

Público34

Figura 2 – Resultado do roteiro

Avaliando os resultados:

Após o experimento responda as seguintes questões:

  • Qual é a principal vantagem de usar o BootsFaces em relação aos componentes padrão

do JSF na criação das interfaces web?

  • Como o uso de componentes BootsFaces, como <b:inputText> e <b:dataTable>,

contribui para a usabilidade e organização visual da aplicação?

  • De que forma o BootsFaces se integra ao JSF, e por que essa integração é importante

para o funcionamento da aplicação?

Checklist:

✓ Criar um projeto com as especificações sugeridas

✓ Criar o pacote model e dentro dele a classe Carro.java

✓ Criar o pacote model e dentro dele a classe CarrosMB.java

✓ Acrescentar a configuração da Managed Bean no arquivo faces-config.xml

✓ Fazer o download do framework BootsFaces

✓ Copiar o JAR para a pasta lib do projeto

✓ Dentro da pasta webappcriar o arquivo pagina.xhtml com o devido código.

✓ Responder as questões.

RESULTADOS

Resultados do experimento:

Público35

O arquivo deverá conter:

  • Capa
  • Folha de rosto com os dados da disciplina e do aluno
  • Métodos: Explique as técnicas que utilizou
  • Resultado:

 Respostas das questões do avaliando resultados.

  • Evidências:

 Captura de tela do projeto.

 Captura de tela do resultado do experimento.

Formato de entrega:

  • Arquivo PDF

Resultados de Aprendizagem:

Após concluir esta atividade, você terá aprendido:

  • A compreender a função dos frameworks Tomahawk, HighFaces e BootsFaces no

aprimoramento das aplicações desenvolvidas com JSF.

  • A utilizar componentes visuais do BootsFaces para construir interfaces web modernas,

responsivas e integradas ao padrão MVC.

  • A integrar o BootsFaces ao JSF, configurando corretamente as bibliotecas e aplicando

seus recursos de forma prática no desenvolvimento de páginas XHTML.

  • A diferenciar os frameworks visuais para JSF, reconhecendo suas vantagens e o contexto

mais adequado para o uso de cada um.

Público36

ROTEIRO DE AULA PRÁTICA

NOME DA DISCIPLINA: PROGRAMAÇÃO WEB II

Unidade: U4_DESENVOLVIMENTO_DE_APLICAÇÕES_COM_API

Aula: A1_API_RESTFULL

OBJETIVOS

Definição dos objetivos da aula prática:

  • Compreender o funcionamento de APIs RESTful e seus princípios básicos.
  • Implementar endpoints usando JAX-RS no Java EE.
  • Produzir e consumir dados no formato JSON.
  • Executar e testar serviços REST em um servidor de aplicação (WildFly).

SOLUÇÃO DIGITAL:

Eclipse

Ide Eclipse ou correlata que possua configurações para construção de classes seguindo o Java

EE, com configurações para ter servidor de aplicação e utilizar o framework JSF para a camada

de visão. Recomenda-se o uso do servidor wilfly.

  1. Acesse o site oficial: https://eclipseide.org/
  2. Clique em Download:
  3. Escolha a versão “Eclipse IDE for Enterprise Java and Web Developers” que compatível

com o sistema operacional do seu computador.

Público37

  1. Após o download, descompacte o já estará pronto para uso.

PROCEDIMENTOS PRÁTICOS E APLICAÇÕES

Procedimento/Atividade nº 1

RESTBOOK – CATÁLOGO DE LIVROS VIA API REST

Atividade proposta:

Nesta atividade, o aluno desenvolverá uma API RESTful utilizando os recursos da especificação

JAX-RS presentes no Java EE (através do servidor WildFly).

A aplicação, chamada RestBook, tem como objetivo expor endpoints REST para listar e cadastrar

livros em formato JSON, aplicando os princípios de comunicação sem estado (stateless) e

padronização de verbos HTTP.

A classe Livro representará o modelo principal da aplicação, contendo os atributos id, titulo e

autor.

Em seguida, será criada a classe LivroResource, responsável por definir os endpoints com as

anotações @Path, @GET, @POST e @Produces(MediaType.APPLICATION_JSON).

Esses endpoints permitirão consultar todos os livros e cadastrar novos livros via requisições

HTTP.

Procedimentos para a realização da atividade:

1) Criar o projeto (Figura 1)

  1. No Eclipse: File > New > Dynamic Web Project.
  2. Nome: RestBook.
  3. Target runtime: selecione o WildFly instalado.
  4. Configuration: “Default Configuration for WildFly”.
  5. Finish.

Público38

Figura 1 – Criando o projeto

2) Certifique-se de que o projeto está com Java 8

  1. Project > Properties > Project Facets: Java 1.8

3) Habilitar JAX-RS (RESTEasy) e JSON

O WildFly já traz o RESTEasy. Para garantir a serialização em JSON via Jackson:

  1. Crie a pasta: src/main/webapp/WEB-INF/ (se não existir).
  2. Dentro dela, crie o arquivo jboss-deployment-structure.xml com o conteúdo:

<jboss-deployment-structure>

<deployment>

<dependencies>

<module name=”org.jboss.resteasy.resteasy-jackson-provider” services=”import”/>

</dependencies>

</deployment>

</jboss-deployment-structure>

Isso adiciona o provider Jackson2 do WildFly ao seu WAR (sem precisar baixar libs).

4) Definir o pacote base

  1. Crie um pacote Java, por exemplo: br.com.restbook

5) Configurar o ponto de entrada do JAX-RS

  1. Crie a classe JaxRsConfig:

package br.com.restbook;

import javax.ws.rs.ApplicationPath;

import javax.ws.rs.core.Application;

@ApplicationPath(“/api”)

public class JaxRsConfig extends Application {

// sem código: a anotação já registra o JAX-RS em /api

}

A sua API responderá em URLs que começam com /api.

6) Criar o modelo (Resource Representation)

  1. Crie a classe Livro:

package br.com.restbook;

public class Livro {

private Integer id;

private String titulo;

private String autor;

public Livro() {}

public Livro(Integer id, String titulo, String autor) {

this.id = id;

this.titulo = titulo;

this.autor = autor;

Público39

}

public Integer getId() { return id; }

public void setId(Integer id) { this.id = id; }

public String getTitulo() { return titulo; }

public void setTitulo(String titulo) { this.titulo = titulo; }

public String getAutor() { return autor; }

public void setAutor(String autor) { this.autor = autor; }

}

package br.com.restbook;

public class Livro {

private Integer id;

private String titulo;

private String autor;

public Livro() {}

public Livro(Integer id, String titulo, String autor) {

this.id = id;

this.titulo = titulo;

this.autor = autor;

}

public Integer getId() { return id; }

public void setId(Integer id) { this.id = id; }

public String getTitulo() { return titulo; }

public void setTitulo(String titulo) { this.titulo = titulo; }

public String getAutor() { return autor; }

public void setAutor(String autor) { this.autor = autor; }

}

7) Criar o recurso REST (endpoints)

  1. Crie a classe LivroResource:

package br.com.restbook;

import java.util.*;

import java.util.concurrent.atomic.AtomicInteger;

import javax.ws.rs.*;

import javax.ws.rs.core.*;

import javax.ws.rs.core.Response.Status;

@Path(“/livros”)

@Produces(MediaType.APPLICATION_JSON)

@Consumes(MediaType.APPLICATION_JSON)

public class LivroResource {

private static final List<Livro> LIVROS = new ArrayList<>();

private static final AtomicInteger SEQ = new AtomicInteger(1);

static {

LIVROS.add(new Livro(SEQ.getAndIncrement(), “Clean Code”, “Robert C. Martin”));

LIVROS.add(new Livro(SEQ.getAndIncrement(), “Effective Java”, “Joshua Bloch”));

}

@GET

public List<Livro> listar() {

return LIVROS; // 200 + JSON

}

Público40

@GET

@Path(“/{id}”)

public Response obter(@PathParam(“id”) int id) {

return LIVROS.stream()

.filter(l -> l.getId() == id)

.findFirst()

.<Response>map(l -> Response.ok(l).build())

.orElse(Response.status(Status.NOT_FOUND).build());

}

@POST

public Response adicionar(Livro novo, @Context UriInfo uriInfo) {

if (novo == null || novo.getTitulo() == null || novo.getAutor() == null) {

return Response.status(Status.BAD_REQUEST).entity(“{\”erro\”:\”Titulo e autor são

obrigatórios\”}”).build();

}

novo.setId(SEQ.getAndIncrement());

LIVROS.add(novo);

UriBuilder uriBuilder =

uriInfo.getAbsolutePathBuilder().path(String.valueOf(novo.getId()));

return Response.created(uriBuilder.build()).entity(novo).build(); // 201 + Location +

JSON

}

@DELETE

@Path(“/{id}”)

public Response remover(@PathParam(“id”) int id) {

boolean removed = LIVROS.removeIf(l -> l.getId() == id);

return removed ? Response.noContent().build() :

Response.status(Status.NOT_FOUND).build();

}

}

8) Deploy no WildFly

  1. Run As > Run on Server (selecione o WildFly).
  2. Verifique no Console se a aplicação subiu sem erros.
  3. Acesse no navegador para testar o GET:
  4. http://localhost:8080/RestBook/api/livros

9) Testes rápidos (Postman ou cURL)

  1. Listar livros (GET)
  2. URL: GET http://localhost:8080/RestBook/api/livros
  3. Headers: Accept: application/json
  4. Obter por id (GET)
  5. URL: GET http://localhost:8080/RestBook/api/livros/1
  6. Adicionar livro (POST)
  7. URL: POST http://localhost:8080/RestBook/api/livros
  8. Headers:
  9. Content-Type: application/json
  10. Accept: application/json
  11. Body (raw/JSON):

{

“titulo”: “Domain-Driven Design”,

“autor”: “Eric Evans”

Público41

}

10) Remover (DELETE)

  1. URL: DELETE http://localhost:8080/RestBook/api/livros/2
  2. cURL exemplo (POST):

curl -i -X POST “http://localhost:8080/RestBook/api/livros” \

-H “Content-Type: application/json” \

-d “{\”titulo\”:\”Refactoring\”,\”autor\”:\”Martin Fowler\”}”

Avaliando os resultados:

Após o experimento responda as seguintes questões:

  • Qual é a principal diferença entre um método REST anotado com @GET e outro com

@POST?

  • Por que o formato JSON é amplamente utilizado em APIs RESTful modernas?
  • Explique o papel da anotação @Path em uma classe que representa um recurso REST.

Checklist:

✓ Criar o projeto “RestBook” no Eclipse (Dynamic Web Project com suporte a JAX-RS).

✓ Configurar a classe Livro com os atributos e métodos getters/setters.

✓ Criar a classe LivroResource com os métodos listarLivros() e adicionarLivro().

✓ Garantir o retorno em JSON usando @Produces(MediaType.APPLICATION_JSON).

✓ Testar os endpoints /livros e /livros/add no Postman ou navegador.

RESULTADOS

Resultados do experimento:

O arquivo deverá conter:

  • Capa
  • Folha de rosto com os dados da disciplina e do aluno
  • Métodos: Explique as técnicas que utilizou
  • Resultado:

 Respostas das questões do avaliando resultados.

  • Evidências:

 Captura de tela do projeto;

 Captura de tela da página dos dois GETs no navegador.

Formato de entrega:

  • Arquivo em Word ou PDF com as capturas de tela.

Resultados de Aprendizagem:

Público42

Ao final desta atividade, o aluno será capaz de:

  • Compreender a estrutura e funcionamento de uma API RESTful desenvolvida em Java

EE, reconhecendo o papel dos recursos, métodos HTTP e formato de troca de dados

(JSON).

  • Implementar e expor endpoints REST utilizando JAX-RS (RESTEasy), aplicando

anotações como @Path, @GET, @POST e @Produces para definir o comportamento da

API.

  • Testar e validar requisições HTTP (GET, POST e DELETE) através de ferramentas como

Postman ou navegador, analisando os códigos de status e as respostas retornadas em

JSON.

  • Configurar e executar uma aplicação REST no servidor WildFly, garantindo o correto

funcionamento do módulo de serialização JSON (Jackson Provider).

Como se realizam os envios?

O seu trabalho é disponibilizado pronto, respondido e nas normas já na mesma hora aqui em nosso site na sua área de downloads e também no seu e-mail.

Em quanto tempo recebo o portfólio?

Os envios são imediatos. Após sua compra, o trabalho já é disponibilizado instantaneamente aqui em nosso site e no seu e-mail.

E se o portfólio que comprei precisar de correção?

Caso haja alguma solicitação de correção/alteração por parte do tutor, basta entrar em contato conosco pelo WhatsApp que providênciaremos sem custo algum.

Qual o formato do arquivo?

Os arquivos são enviados em formato Word e são editáveis.

Caso eu tiver alguma dúvida, terei suporte no pós venda?

Sim, com certeza. Basta clicar no ícone do WhatsApp no cantinho da tela. Será um prazer atendê-lo(a).

Quais os seus canais de contato?

Whatsapp: 53 984751621 – Clicar no canto da tela ou ESCANEIE O QRCODE ABAIXO

projeto de extensão unopar

E-mail:portifoliosp@gmail.com

Portfólio em Word, respondido, completo e já nas normas

Main Menu