1 / 71

Anatomia do JSF – JavaServer Faces

Anatomia do JSF – JavaServer Faces. Rafael Ponte. rponte@gmail.com. Agenda. Quem sou eu? Desenvolvimento de Aplicações Web O que é JavaServer Faces? Por que usar JSF? Overview da tecnologia Conclusão. Quem sou eu?. Rafael Ponte – SCJP 1.4 e estudando para SCWCD

hesper
Download Presentation

Anatomia do JSF – JavaServer Faces

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Anatomia do JSF – JavaServer Faces Rafael Ponte rponte@gmail.com

  2. Agenda • Quem sou eu? • Desenvolvimento de Aplicações Web • O que é JavaServer Faces? • Por que usar JSF? • Overview da tecnologia • Conclusão

  3. Quem sou eu? • Rafael Ponte – SCJP 1.4 e estudando para SCWCD • Sócio fundador da empresa de consultoria e desenvolvimento Triadworks Agile Software Development • Atualmente trabalho como analista programador na IVIA • Trabalha com desenvolvimento Java/JEE desde 2005 • Entusiasta Java e JSF • Moderador da lista de discussão JavaServer Faces Brazilian Group • Técnico em Desenvolvimento de Software pelo CEFET-CE • Ex-aluno frustrado do curso de bacharelado em Matemática da UFC 

  4. Desenvolvimento de Aplicações Web

  5. Introdução Desenvolvimento Web (geralmente) • Aplicações web tornam-se mais e mais importantes • Mais e mais complexidade • Ajax, validação (server vs. client), ... • Exigência mais elevada do cliente durante os anos • Interfaces ricas (fácil de usar) • Prazos cada vez mais curtos • Desenvolvimento considerado difícil • A bola da vez..

  6. Introdução Desenvolvimento Web (Java)

  7. Introdução Model 1 (centrado em páginas)

  8. Introdução Model 1 (Arquitetura centrada em páginas)

  9. Introdução Model 2 (MVC)

  10. Introdução Surgiram diversos frameworks MVC baseado no Model 2 • Apache Struts • WebWork (Struts2) • Spring MVC • Tapestry • E muito outros.. • E continuam surgindo mais

  11. Introdução Problemas • Java não nos fornece o bastante para desenvolvermos aplicações web com produtividade • Dificuldade para integrar vários frameworks (algumas vez nem é possível) • Falta de padrão para um framework web • Ausência de uma API padrão para construir componentes web java • E a solução?

  12. JavaServer Faces! 

  13. O que é JavaServer Faces?

  14. O que é JavaServer Faces? JavaServer Faces é... • ... uma especificação • ... um framework baseado em componentes de interface com o usuário • ... um framework dirigido à eventos • ... padrão de mercado • ... RAD • ... um framework MVC

  15. O que é JavaServer Faces? JavaServer Faces é... • ... uma especificação • JSR 127 (JSF 1.0 e JSF 1.1) – 2004 • JSF 1.0 – não alcançou o sucesso esperado • JSF 1.1 – corrigiu os erros da versão anterior • JSR 252 (JSF 1.2) - 2006 (Java EE 5.0) • JSF 1.2 – melhor compatibilidade com JSP 2.1 e correção de bugs • JSR 314 (JSF 2.0) • Arquitetura, produtividade, ferramentas RAD, AJAX, melhores componentes UI.. • A pergunta é.. quando.. 2007, 2008 ? (Java EE 6.0 ?)

  16. O que é JavaServer Faces? JavaServer Faces é... • ... um framework baseado em componentes de interface com o usuário • JSF é construído sob o conceito de componentes • Os componentes são a base para a construção da interface com o usuário • Existem componentes padrões equivalentes a quase todas as tags HTML e diversos componentes auxiliares • Existem diversas bibliotecas de componentes disponíveis comerciais e open source • Os componentes são expressos através de tags em um JSP e posteriormente transformados em HTML

  17. O que é JavaServer Faces? JavaServer Faces é... • ... um framework dirigido à eventos • Possui um modelo para manipulação de eventos • Componentes geram determinados eventos • Faz chamada à um método (ação no servidor) • O estado da aplicação web muda devido ao evento disparado pelo usuário • Um evento pode ser um click em um botão, focar sobre um input ou mesmo alterar o valor de uma combo-box

  18. O que é JavaServer Faces? JavaServer Faces é... • ... padrão de mercado • É uma especificação (JCP) • Java EE 5.0 • Suporte de Big Players • Sun, Apache, IBM, Oracle, BEA Systems, Borland, ... • IDEs (NetBeans, Eclipse, MyEclipse, JDeveloper, ...) • Implementações (Sun (R.I), Apache, IBM, ...) • Conjuntos de componentes (ADF Faces, Apache MyFaces, WoodStock, IceFaces, JBoss RichFaces, ...)

  19. O que é JavaServer Faces? JavaServer Faces é... • ... RAD (Rapid Application Development) • 4 camadas: • Arquitetura de componentes básica • Conjunto de componentes padrão • Infra-estrutura da aplicação • Ferramenta RAD • JSF padroniza os primeiros três pontos e permite a criação de ferramentas RAD • Utiliza-se IDEs drag-and-drop para construir aplicações: • Sun Studio Creator, NetBeans, JDeveloper etc

  20. O que é JavaServer Faces? JavaServer Faces é... • ... um framework MVC para construir interfaces com o usuário para aplicações web. JSF inclui: • Um conjunto de APIs para: • representar os componentes UI e gerenciar o estado destes componentes • manipular os eventos e validação de entrada do usuário • definir e controlar a navegação entre as páginas • dar suporte a internacionalização e acessibilidade • Duas bibliotecas de tags JavaServer Pages (JSP) para expressar uma interface JavaServer Faces usando uma página JSP

  21. Por que usar JSF?

  22. Por que usar JSF? • É um padrão de mercado • Presente na especificação JEE5.0 e em breve JEE6.0 • Suporte de Big Players • Fácil de usar  E produtivo também! • Fornece separação de funções que envolvem a construção de aplicações Web • Alta abstração para desenvolvimento de aplicação web • Modelo de programação dirigido a eventos (oposto ao modelo HTTP request/response) • Baixa curva de aprendizagem da equipe • Vários pontos de extensão (converters, validators, listeners etc) • Componentes já prontos!

  23. Por que usar JSF? • Reusabilidade e estrutura de componentes extensível • Acessibilidade (browsers, celulares, pda’s, ...)

  24. Por que usar JSF? • Suporte cross-browser  • Segurança • OWASP (Open Web Application Security Project) • cross-site scripting, session hijacking, execução de métodos, ... • Natureza orientada a componentes, validação e pontos de extensão • Grande atividade da comunidade em fóruns, listas de discussão, blogs, portais, revistas, livros etc • Integração com diversos frameworks • Spring, Spring-Annotation, Spring-Webflow, Hibernate, EJB3, JPA, JBoss Seam, Acegi, JAAS, Struts, Struts2, Shale, Tiles, Facelets, Sitemesh, DWR, EXT, Crank, Beehive-Webflow, GWT, Portlets e muitos outros

  25. Por que usar JSF? • Testes unitários • Mock objects • Shale testing framework • Templates • Tiles e Sitemesh • Facelets • IDEs e WYSIWYG (What you see is what you get)

  26. Por que usar JSF? MyEclipse (1)

  27. Por que usar JSF? MyEclipse (2)

  28. Por que usar JSF? MyEclipse (3)

  29. Por que usar JSF? NetBeans (1)

  30. Por que usar JSF? NetBeans (2)

  31. Por que usar JSF? NetBeans (3)

  32. Por que usar JSF? JSFToolbox (1)

  33. Por que usar JSF? JSFToolbox (2)

  34. Por que usar JSF? • Grande variedade de componentes comerciais e open-source disponíveis * Mais componentes? http://www.jsfmatrix.net/

  35. Por que usar JSF? MyFaces (1)

  36. Por que usar JSF? MyFaces (2)

  37. Por que usar JSF? MyFaces (3)

  38. Por que usar JSF? RichFaces (1)

  39. Por que usar JSF? RichFaces (2)

  40. Por que usar JSF? RichFaces (3)

  41. Por que usar JSF? WoodStock (1)

  42. Por que usar JSF? WoodStock (2)

  43. Overview da Tecnologia

  44. Overview da tecnologia Conceitos chaves do JSF • Componentes • Renderers • Managed-beans • Converters / Validators • Navegação • Eventos • Ciclo de vida (Request Lifecycle)

  45. Overview da tecnologia Componentes (1) • Separa a lógica de negócio da apresentação • Cada view é composta por uma hierarquia de componentes

  46. Overview da tecnologia Componentes (2) • Componentes podem ser adicionados na view programaticamente ou via template (JSP por default, ou Facelets para melhor desempenho e fácil desenvolvimento) • Componentes são expressos em tags em uma página JSP • Os componentes padrões são divididos em dois grupos • Faces Core <f:view>, <f:loadBundle>, <f:param> • HTML wrappers <h:dataTable>, <h:selectOneMenu> • Componentes em sua maioria são de interface com o usuário • Componente = class + [renderer] + tag handler (JSP)

  47. Overview da tecnologia Renderers • Responsável por exibir o componente no cliente • São agrupados em render kits • Render kit padrão é o HTML, mas podemos ter WML, SVG etc. • Efetua o encode (gera HTML do componente) • Efetua o decode (seta o componente com os dados da URL query string e do formulário) • Resumindo • <h:inputTextid=“login”size=“16”/> • <inputtype=“text”id=“myForm:login”name=“myForm:login”size=“16”/>

  48. Overview da tecnologia Managed beans • POJO – Plain Old Java Objects • “Linka” a view ao modelo (controller) • Funciona como um “espelho” da view • São acessados via Expression Language (EL) na JSP • Algo semelhante ao Action+ActionForm do Struts • Declarado no faces-config.xml nos possíveis escopos • Application (uma instância por aplicação) • Session (uma instância por sessão/usuário) • Request (uma instância por request) • None (criado sob demanda)

  49. Overview da tecnologia JSF Value Binding • “Binda” valor do componente ao managed-bean • O binding ocorre através de JSF Expression Language (EL) • Semelhante a JSTL, porém usa-se ‘#{}’ no lugar de ‘${}’ • Pode-se executar métodos no modelo através de expressões • Não é processada imediatamente como na JSTL • A partir da JSF 1.2 utiliza-se a Unified Expression Language (JSP 2.1) que resolve problemas de incompatibilidade entre a JSF-EL e JSP-EL • Para cada request o framework • Converte cada valor de entrada (String) em um tipo de objeto Java • Na exibição(output) converte do tipo de objeto Java para String

  50. Overview da tecnologia JSF Value Binding – Exemplo (1) view.jsp Objeto logger

More Related