Exemplo completo com JSF Primefaces + Hibernate + MySQL Read More »
The post Exemplo completo com JSF Primefaces + Hibernate + MySQL appeared first on Aprenda Java.
]]>Hoje criaremos um projeto completo com as tecnologias java: JSF (Primefaces) + Hibernate + MySQL ou PostgreSQL.
E como de costume iniciaremos com uma breve descrição de cada uma delas.
Vamos utilizar o nosso sistema acadêmico chamado de AcademicNet para aplicar os conceitos.
O exemplo funciona tanto com MySQL quanto com PostgreSQL
Nossa aplicação funcionará da seguinte maneira.
A página inicial é a index.jsp Ela faz a apresentação do projeto e quando clicamos na imagem será exibido o menu.jsp nesse menu podemos escolher várias opções de CRUD. A primeira é a mais importante para nós. “Manter Aluno JSF”.
Veja o código abaixo:
Menu de opções
Seja bem vindo ao sistema AcademicNet!
Manter Aluno JSF
Manter Aluno
Listar Alunos
Manter Professor
Listas Professor
Manter Usuario
Listar Usuario
Manter Turma
Listar Turma
Essa opção de menu nos levará até a página de cadastro utilizando JSF.
As primeiras linhas determinam que vamos utilizar JFS, com as URIs dentro da tag . A URI xmlns:p=”http://primefaces.org/ui” informa que utilizaremos o framework Primefaces.
Observe que para cada campo texto temos um atributo value apontando para uma propriedade da entidade aluno. Veja o exemplo de matrícula:
Lista de Alunos
No arquivo web.xml fazemos algumas configurações para que o nosso projeto esteja preparado para executar JSF. Essas configurações são opcionais para utilização do Framework Primefaces.
AcademicNetWebEJB
index.jsp
javax.faces.PROJECT_STAGE
Development
Faces Servlet
javax.faces.webapp.FacesServlet
1
Faces Servlet
*.jsf
*.faces
*.xhtml
Veja o código do nosso “alunoMB”. A novidade aqui é a anotação @ManagedBean. Isso determina que nossa classe é um tipo especial e que pode ser associada a uma
tela. Neste caso este Managed Bean está associado à tela de aluno. Ela tem os métodos necessários para incluir, alterar, consultar, excluir e listar alunos.
package br.com.feltex.academicnet.mb;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import javax.faces.application.FacesMessage;
import javax.faces.bean.ManagedBean;
import javax.faces.context.FacesContext;
import br.com.feltex.academicnet.dao.AlunoDAO;
import br.com.feltex.academicnet.dao.DAOFactory;
import br.com.feltex.academicnet.entidade.Aluno;
@ManagedBean(name = "alunoMB")
public class AlunoMB implements Serializable {
private static final long serialVersionUID = 8103328274400432976L;
private Aluno aluno;
private List lista = new ArrayList<>();
AlunoDAO dao = DAOFactory.getAlunoDAO();
public AlunoMB() {
aluno = new Aluno();
listar();
}
public void alterar() {
System.out.println("Alterar aluno");
dao.alterar(aluno);
listar();
FacesContext.getCurrentInstance().addMessage(
null,
new FacesMessage(FacesMessage.SEVERITY_INFO,
"Manutenção de usuário: ",
"Usuario alterado com sucesso!"));
}
public void consultar() {
long matriculaConsulta = aluno.getMatricula();
System.out.println("Consultar");
aluno = dao.consultar(aluno);
if (aluno == null || aluno.getMatricula() == 0) {
FacesContext.getCurrentInstance().addMessage(
null,
new FacesMessage(FacesMessage.SEVERITY_ERROR,
"Manutenção de usuário: ",
"Usuario não encontrado matrícula:" + matriculaConsulta + "!"));
}
listar();
}
public void excluir() {
System.out.println("Excluir aluno");
dao.excluir(aluno);
listar();
FacesContext.getCurrentInstance().addMessage(
null,
new FacesMessage(FacesMessage.SEVERITY_INFO,
"Manutenção de usuário: ",
"Usuario excluído com sucesso!"));
}
public Aluno getAluno() {
return aluno;
}
public List getLista() {
return lista;
}
public void incluir() {
System.out.println("Incluir aluno");
dao.inserir(aluno);
listar();
FacesContext.getCurrentInstance().addMessage(
null,
new FacesMessage(FacesMessage.SEVERITY_INFO,
"Manutenção de usuário: ",
"Usuario incluido com sucesso!"));
}
public void limpar() {
System.out.println("Limpar");
System.out.println(aluno);
aluno = new Aluno();
}
public void listar() {
System.out.println("Listar aluno");
lista = dao.listar();
}
public void setAluno(Aluno aluno) {
this.aluno = aluno;
}
public void setLista(List lista) {
this.lista = lista;
}
}
Depois compare esse managedBean com o servlet “AlunoServlet”.
O nosso ManagedBean utilizar um padrão de projeto DAOFactory, ou seja, existe uma classe que gera uma instância de um objeto que acessa o Banco de dados.
AlunoDAO dao = DAOFactory.getAlunoDAO();
Código abaixo:
package br.com.feltex.academicnet.dao;
import br.com.feltex.academicnet.dao.hibernate.AlunoHibernateDAO;
import br.com.feltex.academicnet.dao.jdbc.ProfessorDAO;
import br.com.feltex.academicnet.dao.jdbc.ProfessorJDBCDAO;
import br.com.feltex.academicnet.dao.jdbc.TurmaDAO;
import br.com.feltex.academicnet.dao.jdbc.TurmaJDBCDAO;
import br.com.feltex.academicnet.dao.jdbc.UsuarioJDCBDAO;
public class DAOFactory {
public static AlunoDAO getAlunoDAO() {
return new AlunoHibernateDAO();
}
public static ProfessorDAO getProfessorDAO() {
return new ProfessorJDBCDAO();
}
public static TurmaDAO getTurmaDAO() {
return new TurmaJDBCDAO();
}
public static UsuarioDAO getUsuarioDAO() {
return new UsuarioJDCBDAO();
}
}
Por exemplo o método “getAlunoDAO” nos retorna um objeto que acessa o banco de dados via Hibernate e o método getProfessorDAO retorna um acesso ao mesmo Banco de Dados via JDBC. Você pode pensar, mas quando isso seria útil de verdade?
Imagine um sistema que temos Sistema de PDV (Ponto de Vendas). Meu sistema deve estar preparado para acessar qualquer banco de dados. Para isso o meu DAOFactory pode nos atender gerando objetos diferentes de acordo com parâmetros que eu informar.
Minha classe “AlunoHibernateDAO” implementa a interface “AlunoDAO” que define a assinatura de todos os métodos necessários para acesso a banco de dados para a tabela aluno. Neste exemplo todo o controle de transação é gerenciado por nossa aplicação. É o chamado Bean Transation Management.
package br.com.feltex.academicnet.dao.hibernate;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import br.com.feltex.academicnet.dao.AlunoDAO;
import br.com.feltex.academicnet.entidade.Aluno;
import br.com.feltex.hibernate.util.HibernateUtil;
public class AlunoHibernateDAO implements AlunoDAO {
private Session session;
public void alterar(Aluno p) {
try {
session = HibernateUtil.getSession();
session.beginTransaction();
session.update(p);
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
public Aluno consultar(Aluno aluno) {
Aluno retorno = new Aluno();
try {
session = HibernateUtil.getSession();
session.beginTransaction();
retorno = (Aluno) session.get(Aluno.class, aluno.getMatricula());
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
return retorno;
}
public void excluir(Aluno p) {
try {
session = HibernateUtil.getSession();
session.beginTransaction();
session.delete(p);
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
public boolean existe(Aluno aluno) {
Aluno a = consultar(aluno);
return (a.getMatricula() != null);
}
public void inserir(Aluno p) {
try {
session = HibernateUtil.getSession();
session.beginTransaction();
session.save(p);
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
@SuppressWarnings("unchecked")
public List listar() {
List lista = new ArrayList();
try {
session = HibernateUtil.getSession();
session.beginTransaction();
lista = (List) session.createCriteria(Aluno.class).list();
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
return lista;
}
@SuppressWarnings("unchecked")
public List listar(Aluno aluno) {
Criteria c = session.createCriteria(Aluno.class);
if (aluno.getNome().length() > 0) {
c.add(Restrictions.like("nome", aluno.getNome() + "%"));
}
c.addOrder(Order.asc("nome"));
return (List) c.list();
}
}
O arquivo de configuração hibernate.cfg.xml. É nele que informação os dados de configuração de acesso ao banco de dados. Servidor, Porta, Nome do Banco, usuário e senha são as informações básicas para acesso do nosso Banco.
hibernate.dialect => Define qual o "dialeto" será utilizado no banco de dados. Neste caso o dialeto para MySQL. Veja no final deste artigo o link para o catálogo de dialects
hibernate.show_sql => Define se os comandos SQL gerados pelo Hibernate devem ser mostrados. (true ou false)
hibernate.format_sql => Define se os comando SQL terão quebra de linha a parte significativa do script
hibernate.jdbc.batch_size => Define a gravação de dados em lote.
hibernate.hbm2ddl.auto => Possíveis valores e ações
validate: validar o esquema, não faz alterações para o banco de dados.
update: atualizar o esquema.
create: cria o esquema, destruindo dados anteriores.
create-drop: remover o esquema no final da sessão.
No final a tag
ATENÇÃO> Não esqueça de adicionar a annotation @Entity a todas classes que foram informadas nas tags mapping
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/bdacademicnet
root
teco01
org.hibernate.dialect.MySQLDialect
true
true
20
update
DICA: Existem 2 arquivos extras de configuração do Hibernate. Esses arquivos
Caso você queria ver exemplos de configuração para PostgreSQL(hibernate.postgresql.cfg.xml) ou MySQL(hibernate.mysql.cfg.xml).
Servem como apoio para alterações do arquivo: hibernate.cfg.xml
Deixei disponível o projeto completo com o código fonte para auxiliar a todos no processo de aprendizado. Para baixar: Clique aqui
Recomendo que leia: Como gerenciar a transação JPA com Hibernate via Filtro em projeto Web
Leia também: Exemplo completo com JSF Primefaces + EJB + Hibernate + MySQL + JMS (Topic)
Você irá gostar:Bean Transaction Management
Hibernate Manual
Hibernate Dialects
Abraços e bons estudos.
The post Exemplo completo com JSF Primefaces + Hibernate + MySQL appeared first on Aprenda Java.
]]>Instalação e configuração do Tomcat Read More »
The post Instalação e configuração do Tomcat appeared first on Aprenda Java.
]]>Olá Amigos, Hoje iremos fazer a instalação e configuração do Tomcat. O Tomcat é um servidor de aplicação. O Servidor Apache Tomcat é uma software de código fonte aberto para uso das tecnologias Java Servlet e JavaServer Pages (JSP). É um servidor voltado para uso de aplicação Internet e Intranet.
É um dos servidores mais utilizados para desenvolvimento Java.
Mãos à obra.
Acessando a página de download (http://tomcat.apache.org/download-70.cgi),.
Selecione a opção “Binary Distributions”? Core: “zip (pgp, md5)”
Salve o arquivo em uma pasta no seu computador. Descompacte-o em seguida.
Você terá a seguinte estrutura de pastas no diretório do Tomcat.
Agora abra o eclipse e selecione a aba “Servers” conforme imagem abaixo.
a. Caso a aba não esteja disponível vá ao menu: Window => Show View => “Servers”
Selecione a opção “New Server wizard…”
Digite “Tomcat” na primeira caixa de texto e selecione versão do Tomcat que você realizou download aparecerá na lista.
Selecione Next.
Na tela abaixo clique no botão “Browser” e navegue até a pasta onde foi descompactado o TOMCAT.
Clique em “next”. A tela seguinte é para você adicionar os seus projetos ao servidor. No momento não temos nenhum. Clique em Finish.
Pronto. Já temos o Tomcat instalado.
Para iniciá-lo basta clicar no botão “Start” na parte superior da aba “Servers”.
Aparecerão na aba console várias linhas de log de início do servidor.
O importante é ter a mensagem “Informações: Server startup in 1599 ms” que significa que o servidor foi inicializado sem problemas.
**** Não esqueça de parar o servidor em seguida. Isso é importante ser feito durante o processo de desenvolvimento.
Caso você queira instalar seu sistema na Internet existem muitos sites no Brasil e no exterior de hospedagem com preços acessíveis. Veja no link uma busca no Google com alguns deles: aqui
Pronto. Divirtam-se.
Amigos por hoje é só. E vida que segue!
The post Instalação e configuração do Tomcat appeared first on Aprenda Java.
]]>