Download Curso Java y Tecnologías J2EE – Power point

Document related concepts
no text concepts found
Transcript
Java y Tecnologías J2EE
Universidad de Murcia
Curso Formación del PAS
Noviembre 2009
Juan José Meroño Sánchez
Contenidos I

Objetivos del Curso

Curso de introducción al mundo de Java EE.
 Dirigido a:





Nociones básicas de Eclipse.
Mención especial a otras herramientas importantes.
Lenguaje Java




Para saber más: FundeWeb.
Herramientas de Desarrollo



Desarrolladores sin experiencia en Java EE.
Analistas/Jefes de Proyecto inmersos en proyectos Java EE.
Cualquier profesional con ánimo de conocer Java EE.
Nociones básicas de POO.
Nociones básicas de POA.
Nociones básicas de Java y novedades de Java 1.5.
Patrones de Diseño



Ideas generales de patrones de diseño.
Patrones de diseño Web.
El Patrón MVC.
Contenidos II

Arquitectura Java EE





Tecnologías Java EE




Tecnologías de la Vista: JSF y Facelets
Tecnologías de Control: EJB
Tecnologías del Modelo: JPA
Tecnologías Avanzadas Java EE




Modelo de Capas
Contenedores y Servicios Java EE
Ensamblado y Empaquetado Java EE.
Eclipse y Java EE.
Servicios WEB: JAXWS
Autenticación Java EE
Portlets
El Proyecto del Curso

Un periódico digital con teletipo.
I.
Herramientas
de
Desarrollo
I. Herramientas de Desarrollo

Multitud de Herramientas
 Jdeveloper,
NetBeans, IntelliJ, Eclipse,…
 La decisión es clara: Eclipse.
Modular y ampliable mediante plugins.
 Muy utilizada y en constante desarrollo.
 En realidad todas las citadas tienen gran calidad.
 Es la que se emplea en FundeWeb.

 No
sólo sirve para desarrollar Java.
I. Herramientas de Desarrollo
1.Menu: Incluye todas las opciones
del entorno y algunos iconos de
acceso directo a las más empleadas.
2.Perspectiva: Permite alternar entre
las diferentes perspectivas que haya
abiertas.
3.Control Proyecto: Permite controlar
el contenido del proyecto, los archivos
que lo componen.
4.Editor: La zona más amplia para
editar el contenido de los archivos ya
sea visualmente o en modo texto.
5.Propiedades: Utilizada en muchas
ocasiones para editar propiedades del
archivo editado.
6.Control Ejecución: Incluye todo lo
necesario para controlar y monitorizar
la ejecución de nuestro proyecto.
I. Herramientas de Desarrollo

Terminología de Eclipse

Espacio de Trabajo: Workspace




Perspectivas


Configuración predeterminada de las zonas de trabajo adecuadas para un
tipo de tarea concreta: Proyectos Web, Swing, BBDD, etc…
Vistas




Directorio en el que se almacenan los proyectos y configuraciones
específicas.
Se puede cambiar de espacio de trabajo de forma sencilla.
Recomendación: No tener todos los proyectos en un ET.
Pestañas que se ubican en las zonas de trabajo y que permiten hacer
tareas concretas: Editor, Console, Navigator, Server,…
Artefactos de desarrollo: Vistas que nos ayudan a editar el proyecto.
Artefactos de runtime: Vistas que nos ayudan a monitorizar y testar el
proyecto.
Configuración y Actualización de Eclipse



Window >> Preferences.
Podemos ampliar las funcionalidades del IDE según nuestras necesidades.
Help >> Software Updates.
I. Herramientas de Desarrollo

Subversion.
 Eclipse
incluye su control de versiones local
por sesión, pero no es suficiente.
 Mediante el plugin “Subclipse”, se incorporan
a nuestros proyectos todas las posibilidades
del control de versiones.
 Importante emplear Subversión de forma
correcta:
Liberar versiones.
 Emplear comentarios adecuados.
 Crear ramas.

I. Herramientas de Desarrollo

Maven.
 Gestor
de proyectos.
 Forma de compartir el conocimiento de la
metainformación de un proyecto.
<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>org.um.atica</groupId>
<artifactId>Prueba_Maven</artifactId>
<name>Prueba_Maven</name>
<version>0.0.1-SNAPSHOT</version>
<description>Ejemplo de archivo POM de Maven.</description>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.4</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
I. Herramientas de Desarrollo

Maven.
 Incorporar
 Sin
alguien a un proyecto.
Maven
Instalación del software.
 Descarga de fuentes.
 Descarga de librerías.
 Configurar la herramienta para compilar y ejecutar.

 Con
Maven
Instalación del software.
 Descarga de fuentes.
 Ejecución de tarea maven.

I. Herramientas de Desarrollo

Hudson.



Servidores de integración contínua.
Todas las fases de generación de mi proyecto automatizadas.
No necesito personas supervisando tareas automáticas.
Repositorio
Subversion
Desarrollador
1. Commit
4. Resultados
de la Fase de
Test
2. Update
3. Rehace el Proyecto
con Maven
Servidor de
Integración
Contínua
I. Herramientas de Desarrollo

Prácticas I
 Introducción a Eclipse
 Crea un proyecto Java.
 Crea dos clases.
 Cambia la perspectiva entre Java y Resource.
 Perspectivas
 Modifica las vistas que aparecen en la perspectiva Resource.
 Elimina la vista Project Explorer.
 Incluye la vista Navigator y Package Explorer.
 Incluye la vista Problemas.
 Restaura el estado original de la perspectiva.
 Configuración
 Modifica aspectos generales del editor, colores, tipos de
letra, etc…
 Amplia la funcionalidad de eclipse con algún plugin.
I. Herramientas de Desarrollo

Crea un proyecto Java.
I. Herramientas de Desarrollo

Crea dos clases Java.
I. Herramientas de Desarrollo

Instalar un Plugin: Subversion.
I. Herramientas de Desarrollo

Prácticas II
 Gestión de Proyectos
 Modifica las clases Java: Crea un “Hola Mundo”.
 Compara ambas clases.
 Incluye tareas pendientes en ambas clases.
 Visualiza las tareas pendientes.
 Ejecución de Proyectos
 Ejecuta alguna de las clases creadas.
 Incluye puntos de ruptura.
 Observa las posibilidades del Debug.
 Compartir Proyectos
 Comparte tu proyecto en un repositorio.
 Descarga un proyecto desde el repositorio.
I. Herramientas de Desarrollo

Gestionar Proyectos.
II. Lenguaje
Java
II. Lenguaje Java

Definición:
“Lenguaje de programación orientado a objetos desarrollado por
Sun Microsystems a principios de los años 90. El lenguaje toma
mucha de su sintaxis de C y C++, pero tiene un modelo de
objetos más simple y elimina herramientas de bajo nivel, que
suelen inducir a muchos errores, como la manipulación directa de
punteros o memoria.”
II. Lenguaje Java

Programación Orientada a Objetos
 Conceptos
 Clase


Algoritmo asociado a un objeto que se lanza tras recibir un
mensaje.
Atributo


Instancia de una clase, dispone de unas propiedades
concretas.
Método


Definición de propiedades y comportamiento de un tipo.
Objeto


de Diseño
Contenedor de un tipo de dato asociado a un objeto. Notación
punto.
Mensaje

Comunicación dirigida a un objeto. Notación punto.
II. Lenguaje Java

Programación Orientada a Objetos
 Sintaxis
en Java
public class Triangulo {
// Propiedades del triángulo
public int base;
public int altura;
// Métodos del triángulo
public float area() { return (base*altura)/2; }
}
// Ejemplo de Uso
Triangulo t = new Triangulo();
t.Altura = 10; t.base = 2;
System.out.println(“Area: ”+t.area());
II. Lenguaje Java

Programación Orientada a Objetos
 Conceptos

Abstracción


Aumentar la cohesión.
Polimorfismo


Exponer una interface.
Encapsulamiento


Características esenciales del objeto.
Ocultación


de Análisis
Comportamientos diferentes asociados a objetos diferentes
pero con igual nombre.
Herencia

Las clases se relacionan a través de una jerarquía.
II. Lenguaje Java

Programación Orientada a Objetos
 Análisis
en Java
Figura
abstract float area();
Triangulo
float area();
Cuadrado
float area();
II. Lenguaje Java

Programación Orientada a Aspectos

Conceptos Básicos

Aspect


Join Point


Clase a la que se añade el aspecto.
Proxy


Permite añadir métodos o atributos a clases ya existentes.
Target


Define los aspectos a aplicar en cada Join Point.
Introduction


Implementación del aspecto.
Pointcut


Punto de la ejecución donde puede conectarse un aspecto.
Advice


Funcionalidad transversal a implementar.
Objeto creado después de aplicar el aspecto.
Weaving

Proceso de aplicar aspectos a los objetos.
II. Lenguaje Java

Programación Orientada a Aspectos: AspectJ
II. Lenguaje Java

Programación Orientada a Aspectos
 Interceptores
en Java
Una de las formas en las que podemos encontrar
este tipo de programación es con los
interceptores.
 Ciertos objetos disponen de un ciclo de vida.
 Interceptando este ciclo podemos añadir
funcionalidad sin modificar el código del objeto.
 Ejemplo: Auditar los accesos a una aplicación.

Se puede hacer interceptando el ciclo de vida de las
sesiones del servidor.
 Añadiendo esta funcionalidad en el evento de creación.

II. Lenguaje Java

Plataforma Java
 Lenguaje:
Veremos sus características.
 JVM: Máquina virtual.
 API: Biblioteca de librerías.

Ediciones
 Java
ME: Micro Edition.
 Java SE: Standart Edition.
 Java EE: Enterprise Edition.

Desarrollo vs Ejecución
 JSDK:
Kit de desarrollo.
 JRE: Kit de runtime.
II. Lenguaje Java

Elementos del Lenguaje
package curso.ejemplos;
import curso.interfaces.Dibujable;
public class Cuadrado extends Figura implements Dibujable {
private int lado;
public void dibujar() { … }
}
 Package,
Clase
 Herencia, Implementación
II. Lenguaje Java

Elementos del Lenguaje
 Variables
Tipos primitivos: char, byte, short, int, long, float,
double y boolean.
 Objetos y Arrays.
 El ámbito marcado por los bloques { … }.
 Accesibilidad: public, protected, private.
 Ejemplos de declaración:

int x; int y=1;
 Clase c; Clase d = new Clase();
 int [] array; int [] array = {1,2,3,4};
 Clase [] array = new Clase[] {c,d};

II. Lenguaje Java

Elementos del Lenguaje
 Operadores
 Aritméticos: +, -, *, /, %
 Asignación: =, += , -=, *=, /=, %=.
 Incrementales: ++, --.
 Relacionales: >, >=, <, <=, ==, !=.
 Lógicos: &&, ||, !.
 Cadenas: +.
 Bits: >>, <<, &, |, ^, ~.
 Estructuras de Control
 Comentarios: // y /* … */
 Bifurcaciones: if (cond) { … } else { … }
 Bucles: while (cond) { … }, for (init; cond; inc) { … }
II. Lenguaje Java

Elementos del Lenguaje

Excepciones


Control de errores dentro del propio lenguaje.
Implícitas: RuntimeException.


Generadas por errores de programación.
Explícitas: Resto de Exception.

El compilador obliga a chequear estas excepciones.
public void ejemplo (String n, String c) throws Exception {
try {
int num = Integer.parseInt(n);
Class.forName(c);
} catch (NumberFormatException nfe) { throw nfe; }
catch (ClassNotFoundException cnfe) { throw cnfe; }
finally { }
}
II. Lenguaje Java

Elementos del Lenguaje

Multithreading


Capacidad de ejecución en paralelo.
Extender Thread o Implementar Runnable.


Arranque y Parada.
Suspender y Reanudar.
public class HiloThread implements
extends Thread
Runnable
{
{
public
public
private
static
void
Thread
void
run()
t;main(String[]
{
args) {
private String name;
for(int i=0;i<15;i++)
HiloThread
hil=new HiloThread
{
(); hil.setName(”Hilo 1″);
public HiloThread()
HiloThread
{ t = new
hi2=new
Thread(this);
try HiloThread
{ this.sleep(500);
}
(); hil2.setName(“Hilo
System.out.println(this.getName()+”
2”);
en bucle “+i); }
catch(InterruptedException e) { System.out.println(this.getName()+” se cayo intentando dormir”); }
public void setName(String
HiloThread hi3=new
n) { name
HiloThread
= n; }
(); hi3.setName(”Hilo 3″);
}
public String getName()
hil.start();{hi2.start();
return name;
hi3.start();
}
}
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
public void run() {
try {
}
for(int i=0;i<15;i++)
String
{
cmd = br.readLine();
while (!cmd.equals("")) {
try { this.sleep(500); System.out.println(this.getName()+” en bucle “+i); }
if (cmd.equals("1")) hil.stop();
catch(InterruptedException e) { System.out.println(this.getName()+” se cayo intentando dormir”); }
if (cmd.equals("2")) hi2.stop();
}
if (cmd.equals("3")) hi3.stop();
cmd = br.readLine();
}
}
public void start()
} catch
{ t.start();
(Exception
}
ex) {}
}
}
II. Lenguaje Java

Elementos del Lenguaje

Multithreading

Comunicación entre hilos.
public
Productor
Consumidor
Contenedor
extends
{extends
Thread
Thread
{ {
publicclass
class
ProductorConsumidorTest
{
private int
Contenedor
dato;
contenedor;
public static void main(String[] args) {
public Consumidor
private
Productor
boolean hayDato
(Contenedor
(Contenedor
= false;
c) c)
{ contenedor
{ contenedor=
= c;c;
} }
Contenedor c = new Contenedor ();
public synchronized
void run() {
int get() {
Productor
produce
= {new
Productor (c);
for(!hayDato)
int
if
value
(int i == 0;
0; i{<try
10;{ i++)
wait();
} catch (InterruptedException e) { } }
Consumidor
for
hayDato
(int i = 0;
false;
i <consume
contenedor.put(i);
10; i++) { = new Consumidor (c);
notifyAll();
System.out.println("Productor.
value
= contenedor.get();
put: " + i);
produce.start();
return dato;
try { sleep((int)(Math.random() * get:
System.out.println("Consumidor.
100));
" +} value);
catch (InterruptedException e) { }
consume.start();
}
}
}
}
public
synchronized void put(int valor) {
}}
if (hayDato) { try { wait(); } catch (InterruptedException e) { } }
}
dato = valor;
hayDato = true;
notifyAll();
}
}
II. Lenguaje Java

Elementos del Lenguaje: Novedades Java 1.5

Tipos Parametrizados



Autoboxing






import static java.lang.Math;
double raiz = sqrt(1245);
Argumentos Variables


enum EstadoCivil { soltero, casado, divorciado };
EstadoCivil ec = EstadoCivil.casado;
Import Estático


Vector<String> v = new Vector<String>();
for (String c: v) System.out.println(c);
Tipo “enum”


Vector<Integer> v = new Vector<Integer>();
v.addElement(30); // No requiere conversión int – Integer.
Bucles Simples


Vector<String> v = new Vector<String>();
String s = v.elementAt(0); // No requiere casting.
public void miFunc(String p1,int … args) { for (int i:args) { … } }
Metainformación

Anotaciones p.e. @Override.
II. Lenguaje Java

Prácticas I
 Crea
un proyecto Java: Calculadora.
 Crea una calculadora para las 4 operaciones
básicas.
 Como interface usaremos los argumentos de
entrada.

java Calculadora 3 * 5
 Maneja
las excepciones oportunas.
II. Lenguaje Java

Crea un proyecto Java: Calculadora.
public class Calculator {
public class Calculadora {
public static enum Operador { suma , resta, multiplica, divide };
public static void main(String[] args) {
public static double suma(String a,String b) throws CalculatorError {
try {
try { return Double.parseDouble(a)+Double.parseDouble(b); }
double resultado = 0;
catch (Exception ex) { throw new CalculatorError("CalculatorError: "+ex.getMessage()); }
switch (Calculator.aOperador(args[1])) {
}
case suma:
public static double resta(String a,String b) throws Exception {
resultado = Calculator.suma(args[0],args[2]); break;
return Double.parseDouble(a)-Double.parseDouble(b);
case resta:
}
resultado = Calculator.resta(args[0],args[2]); break;
public static double multiplica(String a,String b) throws Exception {
case multiplica:
try { return Double.parseDouble(a)*Double.parseDouble(b); }
resultado = Calculator.multiplica(args[0],args[2]); break;
catch (Exception ex) { System.out.println("CalculatorError en Multiplica."); throw ex; }
case divide:
}
resultado = Calculator.divide(args[0],args[2]); break;
public static double divide(String a,String b) throws NumberFormatException {
}
try { return Double.parseDouble(a)/Double.parseDouble(b); }
System.out.println(args[0]+" "+args[1]+" "+args[2]+" = "+resultado);
catch (NumberFormatException nfe) { throw nfe; }
} catch (Exception ex) {
}
ex.printStackTrace();
public static Operador aOperador(String op) throws CalculatorError {
}
if (op!=null) {
}
if (op.toLowerCase().equals("mas")) return Operador.suma;
if (op.toLowerCase().equals("menos")) return Operador.resta;
}
if (op.toLowerCase().equals("por")) return Operador.multiplica;
if (op.toLowerCase().equals("entre")) return Operador.divide;
public
class CalculatorError extends Exception {
}
public
CalculatorError(String
msg) { super(msg);
}
throw new
CalculatorError("CalculatorError:
Operador
incorrecto.");
}}
}
II. Lenguaje Java

Prácticas II: El diario digital.
 La
práctica global del curso consiste en la
creación de un Diario Digital.
 El Diario es un simple listado de noticias, y
cada noticia pertenece a una categoría.
 La portada del Diario estará formada por las
noticias de última hora (novedades).
 Las noticias se componen de un título, una
fecha y el contenido.
 Crea las clases que creas necesarias y una
sencilla interface para testarlas.
II. Lenguaje Java

Prácticas II: El diario digital.
public class Noticia {
private int codigo;
private String contenido;
private Date fecha;
public
class Categoria {
private boolean
portada;
private int codigo;
private String titulo;
private String nombre;
private Categoria categoria;
private List<Noticia> noticias;
public Noticia() { }
public Categoria() { }
public int getCodigo() { return this.codigo; }
int{ this.codigo
getCodigo()={ return
}
public void setCodigo(intpublic
codigo)
codigo;this.codigo;
}
public
void this.contenido;
setCodigo(int codigo)
{ this.codigo = codigo; }
public String getContenido()
{ return
}
public String
getNombre()
{ return=this.nombre;
public void setContenido(String
contenido)
{ this.contenido
contenido; } }
public this.fecha;
void setNombre(String
nombre) { this.nombre = nombre; }
public Date getFecha() { return
}
public
List<Noticia>
public void setFecha(Date
fecha)
{ this.fechagetNoticias()
= fecha; } { return this.noticias; }
public
void
setNoticias(List<Noticia>
noticias) { this.noticias = noticias; }
public boolean isPortada() { return this.portada; }
public void }setPortada(boolean portada) { this.portada = portada; }
public String getTitulo() { return this.titulo; }
public void setTitulo(String titulo) { this.titulo = titulo; }
public Categoria getCategoria() { return this.categoria; }
public void setCategoria(Categoria categoria) { this.categoria = categoria; }
}
III. Patrones
de
Diseño
III. Patrones de Diseño

Definición:
 “Esquemas
predefinidos aplicables en
diversas situaciones que garantizan ciertas
cualidades al diseño obtenido.”

Motivación:
 Un
porcentaje muy elevado de los problemas
a los que nos enfrentamos ya han sido
resueltos anteriormente por otras personas.

“Design Patterns”, Gang of Four, (Erich Gamma,
Richard Helm, Ralph Johnson y John Vlisides)
III. Patrones de Diseño

División GoF
 Patrones
Creacionales: Abstraer el proceso de
creación de los objetos.

Abstract Factory, Builder, Factory Method, Prototype y
Singleton.
III. Patrones de Diseño

Abstract Factory: Crear familias de objetos.
DocumentBuilderFactory fac = new DocumentBuilderFactory();
DocumentBuilder builder = fac.newDocumentBuilder(); // Retorna una implementación de Builder Concreto

Builder: Simplificar la creación en si.
DocumentBuilder builder = fac.newDocumentBuilder();
Document doc = builder.newDocument(); // Retorna un documento vacío
Document doc = builder.parse(cadena); // Retorna un documento tras parsear la cadena


Abstract Factory: Permite crear un builder diferente según la
implementación de XML disponible.
Builder: Simplifica procesos de creación complejos para un
documento.
III. Patrones de Diseño

División GoF
 Patrones
Estructurales: Combinar objetos para
crear estructuras de mayor tamaño.

Adapter, Bridge, Composite, Decorator, Facade, Flyweight y
Proxy.
III. Patrones de Diseño

Decorator: Añadir funcionalidad a un objeto.
JFrame frame = new JFrame();
frame.getComponentPane().add(JLabel(“Un Texto”));
frame.getComponentPane().add(JLabelConBorde(“Un Texto”));
frame.getComponentPane().add(JLabelResizable(“Un Texto”));
…
frame.getComponentPane().add(new BorderDecorator(JLabel(“Un Texto”)));
frame.getComponentPane().add(new ResizableDecorator(JLabel(“Un Texto”)));
frame.getComponentPane().add(new ResizableDecorator(new BorderDecorator(JLabel(“Un Texto”))));
…
public class BorderDecorator extends JComponent {
protected JComponent child; // decorated component
public BorderDecorator(JComponent component) {
child = component;
this.setLayout(new BorderLayout());
this.add(child);
}
public void paint(Graphics g) {
super.paint(g);
g.drawRect(0, 0, this.getWidth() - 1, this.getHeight() - 1);
}
}
III. Patrones de Diseño

División GoF
 Patrones
Comportamiento: Definir interacción
entre objetos reduciendo el acoplamiento.

Chain of Responsability, Command, Interpreter, Iterator,
Mediator, Memento, Observer, State, Strategy, Template
Method y Visitor.
III. Patrones de Diseño

Observer: Patrón muy empleado.
public class ObservableValue extends Observable {
private int n = 0;
public ObservableValue(int n) { this.n = n; }
public void setValue(int n) {
this.n = n; setChanged();
notifyObservers();
}
public int getValue() { return n; }
}
public class TextObserver implements Observer {
public void update(Observable obs, Object obj) { System.out.println(((ObservableValue)ov).getValue()); }
}
public static void main(String[] args) {
ObservableValue ov = new ObservableValue(0);
TextObserver to = new TextObserver();
ov.addObserver(to);
ov.setValue(145); // Este cambio se notifica al Observer
}
III. Patrones de Diseño

Patrones Web
 Al
amparo de los patrones de diseño del GoF
aparecen otra serie de patrones específicos
del mundo Web.

http://java.sun.com/blueprints/corej2eepatterns/Pat
terns/index.html
 Se
distribuyen en tres capas: Presentación,
Negocio e Integración.
 De entre todos los patrones Web existentes el
más conocido y empleado es el MVC.
III. Patrones de Diseño

Modelo Vista Control: Descrito en 1979.
 Modelo: Representación específica de la información.
 Vista: Representación del modelo en un formato adecuado
para que el usuario interactúe.
 Control: Responde a la interacción del usuario con la vista
provocando cambios en el modelo.
III. Patrones de Diseño
Modelo Simplificado

public
Observable
{ {
publicclass
classCliente
Serverextends
implements
Observer
private String link = "";
private boolean enviado = false;
}
}
public
void link(String l) {
@Override
= l;
public void link
update(Observable
o, Object arg) {
setChanged();
String action =notifyObservers();
((Cliente)o).getLink();
}
// Se pincha un enlace
if (action.equals(“Index")) {
public String getLink() { return
link; }
System.out.println("Retorno
Página Index !!");
} else if (action.equals(“Send")) {
public static void main(String[]
args)= {true; System.out.println("Respuesta de Send !!");
enviado
Cliente
c=
new Cliente();
} else if
(action.equals(“Verify"))
{
c.addObserver(new
Server());
if (enviado) System.out.println("Send ya ejecutado !!");
// Petición Inicial
else System.out.println("Send no ejecutado !!");
c.link(“Index");
}
// Verifico
}
c.link(“Verify");
// Envio Formulario
c.link(“Send");
// Verifico
c.link(“Verify");
}
III. Patrones de Diseño

Modelo Simplificado
public
Server implements
{
Observer {
VISTAclass Control
private Control
private
control
Modelo
= new
model
Control();
= new Modelo();
public class Vista {
@Override public Vista doAction(String action) {
public voidprivate
update(Observable
try { String text; o, Object arg) {
String
return
action
(Vista)this.getClass().getMethod("do"+action,
= ((Cliente)o).getLink();
new Class[]{}).invoke(this,new Object[]{});
public
Vista(String
t)
{
text
=
t;
}
Vista
} catch
vista(Exception
= control.doAction(action);
e) {
vista.send();
return new Vista("Error: "+e);
public
void send() { System.out.println(text); }
}
}
}
}
}
public Vista doIndex() {
return new Vista("Retorno Página Index.");
}
MODELO
public Vista doSend() {
model.setEnviado(true);
return new Vista("Respuesta de Send.");
public class Modelo {
}
private boolean enviado = false;
public Vista doVerify() {
if (model.isEnviado())
return new
Vista("Send
ya ejecutado.");
public void setEnviado(boolean
enviado)
{ this.enviado
= enviado;
}
return new Vista("Send no ejecutado.");
}public boolean isEnviado() { return enviado; }
}
}
III. Patrones de Diseño

Modelo Vista Control
 Unidos
a este modelo aparecen otras dos
estrategias.

Inversión de Control (IoC)
Empleada en todos los frameworks de desarrollo.
 Principio Hollywood: “No me llames, ya te llamo yo”.


Inyección de Dependencias (DI)
Configurar vs Programar.
 Simplifica la obtención de recursos comunes.
 Utilización de las anotaciones.

III. Patrones de Diseño

Inversión de Control
public class Control {
public class SubControl extends Control {
public Vista doAction(String action) {
try
{
private
Modelo model = new Modelo();
return (Vista)this.getClass().getMethod("do"+action, new Class[]{}).invoke(this,new Object[]{});
}public
catch Vista
(Exception
e) { {
doIndex()
return new return
Vista("Error:
"+e);
new Vista("Retorno
Página Index.");
}}
}
}
public Vista doSend() {
model.setEnviado(true);
return new Vista("Respuesta de Send.");
}
public Vista doVerify() {
if (model.isEnviado()) return new Vista("Send ya ejecutado.");
return new Vista("Send no ejecutado.");
}
}
III. Patrones de Diseño
Inyección de Dependencias

public class Server implements Observer {
private Control control;
public Server() {
public class Server implements Observer {
// Código que instancia un objeto de la subclase de control
@Controlador(name=SubControl)
// adecuada para manejar las peticiones de la aplicación
private Control control;
}
@Override
public void update(Observable o, Object arg) {
@Override
String action = ((Cliente)o).getLink();
public void update(Observable o, Object arg) {
Vista vista = control.doAction(action);
String action = ((Cliente)o).getLink();
vista.send();
Vista vista = control.doAction(action);
}
vista.send();
}
}
}
III. Patrones de Diseño

Prácticas
 Repasa
los diferentes patrones del GoF y
localiza los más adecuados para estos
problemas:
Dotar de un sistema de undo/redo a un editor.
 Crear un sistema gestor de ventanas que permita
crear ventanas con diferentes características.
 Crear un sistema de actualizaciones automáticas
en función de la variación de diversos objetos.
 Crear números aleatorios permitiendo emplear
diversas API’s de generadores de números
aleatorios.
 Asegurar la aleatoriedad de dichos números.

III. Patrones de Diseño

Prácticas

Memento.



Decorator.




Crear un sistema de actualizaciones automáticas en función de la variación
de diversos objetos.
Es un patrón específico para este tipo de trabajo.
Abstract Factory.



Crear un sistema gestor de ventanas que permita crear ventanas con
diferentes características.
De este modo se pueden crear ventanas que mezclen diferentes
características sin necesidad de crear todas las combinaciones.
Observer.


Dotar de un sistema de undo/redo a un editor.
Es un patrón específico para este tipo de trabajo.
Crear números aleatorios permitiendo emplear diversas API’s de
generadores de números aleatorios.
Builder puede ser excesivo mejor para tratar de simplificar la construcción.
Singleton

Asegurar la aleatoriedad de dichos números.
IV. Arquitectura
Java EE
IV. Arquitectura Java EE

Modelo de Capas
 A medida
que evolucionan las aplicaciones
Web, surge la necesidad de organizarlas.
 Inicialmente se emplean 3 capas.
 Actualmente es más adecuado el uso de 4.
IV. Arquitectura Java EE

Contenedores Java EE
 Entorno
de ejecución específico para un conjunto de
objetos de un determinado tipo y con unos fines
concretos.
IV. Arquitectura Java EE

Servicios Java EE
 Para
cada contenedor Java EE proporciona una serie
de servicios, como por ejemplo:










Java Transaction API (JTA)
Java Persistence API (JPA)
Java Message Service (JMS)
Java Naming Direct Interface (JNDI)
JavaMail
Java Beans Active Framework (JAF)
Java API for XML Procesing (JAXP)
Java EE Connector Arquitecture
Java Authentication and Authorization Service (JAAS)
Servicios Web (JAXWS)
IV. Arquitectura Java EE

Ensamblado y Empaquetado
 Módulo

EAR
Contienen una aplicación completa.



/*.war
/*.jar
/META-INF/application.xml
<?xml version="1.0" encoding="ASCII"?>
<application xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:application="http://java.sun.com/xml/ns/javaee/application_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/application_5.xsd" version="5">
<display-name>EjemploEAR</display-name>
<module>
<web>
<web-uri>Ejemplo.war</web-uri>
<context-root>Ejemplo</context-root>
</web>
</module>
</application>
IV. Arquitectura Java EE

Ensamblado y Empaquetado
 Módulo

Contienen un módulo web.





/*.*
/WEB-INF/web.xml
/WEB-INF/classes/*.class
/WEB-INF/lib/*.jar
Dentro del módulo web:



 El
WEB
Servlets
Filters
Listeners
contenido varia mucho en función del tipo de
desarrollo utilizado.
IV. Arquitectura Java EE

Ensamblado y Empaquetado: Módulo WEB
<web-app … id="DiarioDigital" version="2.5">
<display-name>DiarioDigital</display-name>
<description>DiarioDigital</description>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
<filter>
<display-name>RichFaces Filter</display-name>
<filter-name>richfaces</filter-name>
<filter-class>org.ajax4jsf.Filter</filter-class>
</filter>
<filter-mapping>
<filter-name>richfaces</filter-name>
<servlet-name>Faces Servlet</servlet-name>
</filter-mapping>
<listener><listener-class>com.sun.faces.config.ConfigureListener</listener-class></listener>
<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>*.jsf</url-pattern>
</servlet-mapping>
</web-app>
IV. Arquitectura Java EE

Ensamblado y Empaquetado
 Módulo

Contienen un módulo EJB.



EJB
/*.class
/META-INF/ejb-jar.xml
El uso de anotaciones simplifica el contenido del descriptor.
<?xml version="1.0" encoding="UTF-8"?>
<ejb-jar version="3.0" 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/ejb-jar_3_0.xsd">
<display-name>SimpleEJB</display-name>
</ejb-jar>
IV. Arquitectura Java EE

Servlets
 Clase
Java con un ciclo de vida concreto.
Init: Ejecutado al cargarse la primera vez.
 doGet/doPost/do…: Ejecutados al recibirse
peticiones de cada tipo concreto.
 Destroy: Ejecutado al finalizar.

 Importante:
Se ejecuta en un hilo.
 Request/Response/Session.
IV. Arquitectura Java EE

JSP’s



Al estilo de otros lenguajes, escribir código Java dentro de
HTML.
Se compila y se convierte en un servlet. Maneja los mismos
objetos.
Custom Tags. Ampliar la sintaxis de HTML.
<%@
page
language="java"
contentType="text/html;
charset=ISO-8859-1"
public
class
MiServlet extends
HttpServlet {
pageEncoding="ISO-8859-1"%>
public MiServlet() { super(); }
<!DOCTYPE
PUBLIC
"-//W3C//DTD HTML 4.01
Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
protectedhtml
void
service(HttpServletRequest
request,
HttpServletResponse
response)
<html>
throws ServletException, IOException {
<head>
response.getWriter().println("<html>");
<meta http-equiv="Content-Type"
content="text/html; charset=ISO-8859-1">
response.getWriter().println("<head><title>Ejemplo</title></head>");
<title>Ejemplo</title>
response.getWriter().println("<body>Hola "+request.getParameter("nombre")+"</body>");
</head>
response.getWriter().println("</html>");
<body>
}
Hola
} <%=request.getParameter("nombre") %>.
</body>
</html>
IV. Arquitectura Java EE

Custom Tags
package tag;
fichero.jsp
/WEB-INF/tlds/MiTag.tld
import
javax.servlet.jsp.tagext.*;
<?xml
version="1.0"
encoding="UTF-8"?>
<%@taglib
prefix="t"
uri="MisTags" %>
import
javax.servlet.jsp.*;
<taglib version="2.0" xmlns="http://java.sun.com/xml/ns/j2ee"
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
pageEncoding="ISO-8859-1"%>
public
class xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
MiTag extends SimpleTagSupport {
web-jsptaglibrary_2_0.xsd">
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
public void doTag() throws JspException {
"http://www.w3.org/TR/html4/loose.dtd">
<tlib-version>1.0</tlib-version>
PageContext pageContext = (PageContext) getJspContext();
<html>
<short-name>MTags</short-name>
JspWriter out = pageContext.getOut();
<uri>MisTags</uri>
<head>
try {
<metaout.println("Hello
http-equiv="Content-Type"
content="text/html; charset=ISO-8859-1">
World");
<tag>
<title>Insert
title here</title>
} catch (Exception
e) { }
<name>mitag</name>
</head>
}<tag-class>tag.MiTag</tag-class>
<body>
<body-content>empty</body-content>
}</tag>
<t:mitag/>
</body>
</taglib>
</html>
IV. Arquitectura Java EE

Custom Tags: Argumentos.
package
tag;
/WEB-INF/tlds/MiTag.tld
fichero.jsp
import
javax.servlet.jsp.tagext.*;
<?xml
version="1.0"
encoding="UTF-8"?>
<%@taglib
prefix="t"
uri="MisTags" %>
import
javax.servlet.jsp.*;
<taglib version="2.0" xmlns="http://java.sun.com/xml/ns/j2ee"
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
pageEncoding="ISO-8859-1"%>
public
class xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
MiTag extends SimpleTagSupport {
web-jsptaglibrary_2_0.xsd">
<!DOCTYPE
html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
<tlib-version>1.0</tlib-version>
private String propiedad;
<short-name>MTags</short-name>
"http://www.w3.org/TR/html4/loose.dtd">
<uri>MisTags</uri>
<html>
public void setPropiedad(String p) { propiedad = p; }
<tag>
<head>
<name>mitag</name>
<meta
http-equiv="Content-Type"
content="text/html;
charset=ISO-8859-1">
public
void doTag() throws JspException
{
<tag-class>tag.MiTag</tag-class>
<title>Insert
titlepageContext
here</title>= (PageContext) getJspContext();
PageContext
<body-content>empty</body-content>
JspWriter out = pageContext.getOut();
</head>
<attribute>
try
{
<name>propiedad</name>
<body>
out.println("Hello World: "+propiedad);
<rtexprvalue>true</rtexprvalue>
<t:mitag propiedad=“Una Propiedad”/>
}<required>false</required>
catch (Exception e) { }
}</attribute><t:mitag propiedad=“${param[‘nombre’]}”/>
</body>
</tag>
}</html>
</taglib>
IV. Arquitectura Java EE

Custom Tags: Body
package tag;
/WEB-INF/tlds/MiTag.tld
import
javax.servlet.jsp.tagext.*;
fichero.jsp
import javax.servlet.jsp.*;
<?xml class
version="1.0"
encoding="UTF-8"?>
public
MiTag extends
SimpleTagSupport {
<%@taglib
prefix="t"
<taglib
version="2.0"
public void doTag() xmlns="http://java.sun.com/xml/ns/j2ee"
throwsuri="MisTags"
JspException { %>
<%@
pagexmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
language="java"
contentType="text/html; charset=ISO-8859-1"
JspFragment
body = getJspBody();
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
PageContext
pageContext = (PageContext) getJspContext(); web-jsptaglibrary_2_0.xsd">
pageEncoding="ISO-8859-1"%>
JspWriter out html
= pageContext.getOut();
<!DOCTYPE
PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
<tlib-version>1.0</tlib-version>
try
{
"http://www.w3.org/TR/html4/loose.dtd">
<short-name>MTags</short-name>
StringWriter stringWriter = new StringWriter();
<html>
<uri>MisTags</uri>
StringBuffer buff = stringWriter.getBuffer();
<head>
buff.append("<h1>");
<tag>
<meta
http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
body.invoke(stringWriter);
<name>mitag</name>
buff.append("</h1>");
<title>Insert
title here</title>
<tag-class>tag.MiTag</tag-class>
out.println(stringWriter);
</head>
</tag>
} catch (Exception e) { }
<body>
}
<t:mitag>Texto Interno</t:mitag>
} </taglib>
</body>
</html>
IV. Arquitectura Java EE

Custom Tags: Simplificado
/WEB-INF/tags/mitag.tag
fichero.jsp
* Simple
*
<%@
taglib!!prefix="t" tagdir="/WEB-INF/tags" %>
Hola
Mundo
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
* Con
Parámetros *
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<%@attribute
name="color" required="true" %>
<html>
<font
color=“${pageScope.color}”>Hola Mundo!!</font>
<head> theColor = (String) pageContext.getAttribute("color"); %>
<%String
<meta
http-equiv="Content-Type" content="text/html;
<font
color=“<%=theColor%>”>Hola
Mundo!!</font>charset=ISO-8859-1">
<title>Insert title here</title>
</head>
* Con
Contenido *
<body>
<%@attribute<t:mitag/>
name="color" required="true" %>
<t:mitag color=“red”/>
<font color=“${pageScope.color}”><jsp:doBody/></font>
color=“red”>Texto</t:mitag>
<jsp:doBody<t:mitag
var="theBody"/>
</body> bc = (String) pageContext.getAttribute("theBody"); %>
<%String
</html>
<font
color=“${pageScope.color}”><%= bc.toUpperCase() %></font>
IV. Arquitectura Java EE

Prácticas
 Crea
un Server WebLogic11g.
 Crea un Dynamic Web Project sobre el
servidor.
 Añade un Servlet/JSP/CustomTag.
 Añade un Filtro.
 Añade un Listener.
 Añade una página index con un enlace al
servlet/jsp.
 Incluye la vista “TCP/IP Monitor” y úsala.
IV. Arquitectura Java EE

Crea un Servidor WebLogic.
IV. Arquitectura Java EE

Crea un Dynamic Web Project.
IV. Arquitectura Java EE

Añade un Servlet.
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
ServletOutputStream out = response.getOutputStream();
out.println("<html>");
out.println("<head><title>MiServlet</title></head>");
out.println("<body>");
long numero = 0;
HttpSession session = request.getSession(true);
if (session.isNew()) {
out.println("<h1>Acabo de pensar un número del 1 al 10, adivina cuál es:</h1>");
session.setAttribute("MiNumero", Math.round(Math.random()*10+1));
} else {
out.println("<h1>Tengo pensado un número del 1 al 10, adivina cuál es:</h1>");
numero = (Long)session.getAttribute("MiNumero");
}
if (request.getParameter("number")!=null) {
try {
if (Long.parseLong(request.getParameter("number")) == numero) { out.println("<h2>¡ Has Acertado !</h2>"); }
else { out.println("<h2>Lo siento, vuelve a intentarlo.</h2>"); }
} catch (NumberFormatException nfe) { out.println("<h2>Debes escribir un número.</h2>"); }
}
out.println("<form method=\"post\">");
out.println("<label>Tu numero:</label><input type=\"text\" name=\"number\"/>");
out.println("</form>");
out.println("</body>");
out.println("</html>");
out.flush(); out.close();
}
IV. Arquitectura Java EE

Añade un Filtro.
int minHour = 0;
int maxHour = 24;
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException,ServletException {
int hora = Calendar.getInstance().get(Calendar.HOUR_OF_DAY);
if (hora>=minHour && hora<=maxHour)chain.doFilter(request, response);
else {
ServletOutputStream out = res.getOutputStream();
out.println("<html>");
out.println("<head><title>MiServlet</title></head>");
out.println("<body><h1>Sólo juego de "+minHour+" a "+maxHour+".</h1></body>");
out.println("</html>");
out.flush(); out.close();
}
}
public void init(FilterConfig fConfig) throws ServletException {
try {
minHour = Integer.parseInt(fConfig.getInitParameter("minimo"));
maxHour = Integer.parseInt(fConfig.getInitParameter("maximo"));
if (minHour>23 || minHour<0 || maxHour>23 || maxHour<0 || minHour>maxHour) throw new Exception("Hora no válida.");
} catch (Exception ex) {
System.out.println("Formato Hora Incorrecto!");
}
IV. Arquitectura Java EE

Añade un Listener.
public void attributeRemoved(HttpSessionBindingEvent arg0) { }
public void attributeAdded(HttpSessionBindingEvent arg0) {
System.out.println("Acaba de Pensarse en el: "+arg0.getSession().getAttribute("MiNumero"));
}
public void attributeReplaced(HttpSessionBindingEvent arg0) { }
V. Tecnologías
Java EE
V. Tecnologías Java EE

Tecnologías Vista: JSF
 Estándar
SUN: Existen muchas alternativas.
Comunidad de desarrollo amplia.
 Apoyo tecnológico de las principales compañías.
 Adaptación de las mejores ideas de otros.
 Lentitud en asimilar nuevas tecnologías.
 Modificaciones o mejoras lentas.
 Dependencia de implementaciones de terceros.

V. Tecnologías Java EE

Tecnologías Vista: JSF
 Componentes

API + Implementación de Referencia.


de JSF:
Representan componentes UI y manejan su estado, eventos,
validaciones, navegación, etc…
Librería de Etiquetas.

Etiquetas personalizadas de JSP para dibujar los componentes
UI dentro de las páginas JSP.
V. Tecnologías Java EE

Ciclo de Vida JSF
 Las
peticiones Faces no se limitan a peticiónrespuesta, disponen de un ciclo de vida.
 El ciclo de vida depende del tipo de petición.




 El
Respuesta No-Faces: Respuesta generada al margen de la
fase de renderizar respuesta de faces.
Respuesta Faces: Respuesta generada en la fase de
renderizar respuesta de faces.
Petición No-Faces: Petición enviada a un componente no
faces.
Petición Faces: Petición enviada desde una respuesta faces
previamente generada.
escenario normal Peticion faces/Respuesta faces.
V. Tecnologías Java EE

Ciclo de Vida JSF
V. Tecnologías Java EE

Ciclo de Vida JSF
 Reconstruir el árbol de componentes.
 Se construye el árbol de componentes faces.
 Aplicar valores a la petición.
 Se asocian a los componentes los nuevos valores desde los
parámetros de la petición.
 Procesar validaciones.
 Se procesan las validaciones para los componentes.
 Actualizar los valores del modelo.
 Una vez es válido se actualizan los valores del modelo.
 Invocar aplicación.
 En este punto se manejan los eventos a nivel de aplicación.
 Renderizar respuesta.
 Por último se dibujan los componentes del árbol.
V. Tecnologías Java EE

Componentes JSF
 Conjunto de clases UIComponent.
 Representan los componentes.
 Modelo de renderizado.
 Forma de visualizar el componente.
 Modelo de eventos.
 Forma de manejar los eventos lanzados.
 Modelo de conversión.
 Conectar conversores de datos al componente.
 Modelo de validación.
 Forma de registrar validadores para el componente.


Se emplean las etiquetas.
RichFaces, ICEFaces: Librerías de etiquetas.
V. Tecnologías Java EE

Componentes JSF
<h:dataTable id="noticias" value="#{Noticias.listadoCategoria}" var="noti">
<h:column>
<f:facet name="header"><h:outputText value="Titular"/></f:facet>
<h:outputText value="#{noti.titulo}" />
</h:column>
<h:column>
<f:facet name="header"><h:outputText value="Contenido"/></f:facet>
<h:outputText value="#{noti.contenido}" />
</h:column>
</h:dataTable>
--------------------------------------------------------------------------------------------------------------------------------------------------------------<h:form id=“NoticiaForm”>
<h:outputText value="Código:"/>
<h:inputText id="codigo" value="#{GestorNoticias.noticia.codigo}" required="true" /><br/>
<h:outputText value="Titulo:"/>
<h:inputText id="titulo" value="#{GestorNoticias.noticia.titulo}" required="true" /><br/>
<h:outputText value="Contenido:"/>
<h:inputText id="contenido" value="#{GestorNoticias.noticia.contenido}" required="true" /><br/>
<h:outputText value="Fecha:"/>
<h:inputText id="fecha" value="#{GestorNoticias.noticia.fecha}" required="true">
<f:convertDateTime pattern="dd/MM/yyyy"/>
</h:inputText><br/>
<h:outputText value="Portada:"/>
<h:selectBooleanCheckbox id="portada" value="#{GestorNoticias.noticia.portada}" required="true" /><br/>
<h:outputText value="Categoria:"/>
<h:selectOneMenu id="categoria" value="#{GestorNoticias.categoriaId}">
<f:selectItems value="#{GestorNoticias.selectCategorias}" />
</h:selectOneMenu><br/>
<h:commandButton value="Guardar" action="#{GestorNoticias.saveNoticia}" />
</h:form>
http://java.sun.com/javaee/javaserverfaces/reference/docs/
http://java.sun.com/javaee/javaserverfaces/1.2/docs/tlddocs/
http://java.sun.com/javaee/javaserverfaces/1.2_MR1/docs/api/index.html
V. Tecnologías Java EE

Faces-Config.xml
 Archivo

de configuración principal.
Describe los bean manejados.
<managed-bean>
<description>Noticiero</description>
<managed-bean-name>GestorNoticias</managed-bean-name>
<managed-bean-class>web.GestorNoticias</managed-bean-class>
<managed-bean-scope>application/session/request/none</managed-bean-scope>
<context-param>
</managed-bean>
<param-name>javax.faces.CONFIG_FILES</param-name>
<param-value>/WEB-INF/faces-config.xml,/WEB-INF/faces-beans.xml</param-value>
 Describe las reglas de navegación.
</context-param>
<navigation-rule>
<from-view-id>/editar/editar.xhtml</from-view-id>
<navigation-case>
<from-outcome>nuevaCategoria</from-outcome>
<to-view-id>/editar/new/categoria.xhtml</to-view-id>
</navigation-case>
<navigation-case>
<from-outcome>nuevaNoticia</from-outcome>
<to-view-id>/editar/new/noticia.xhtml</to-view-id>
</navigation-case>
</navigation-rule>
V. Tecnologías Java EE

JSF Paso a Paso
 Ciclo de Vida
 Podemos crear un Listener.

Escucha la fase indicada en getPhaseId.
public class PhaseListener implements javax.faces.event.PhaseListener {
public void afterPhase(PhaseEvent event) { System.out.println("AFTER - "+event.getPhaseId()); }
public void beforePhase(PhaseEvent event) { System.out.println("BEFORE - "+event.getPhaseId()); }
public PhaseId getPhaseId() { return PhaseId.ANY_PHASE; }
}
/WEB-INF/faces-config.xml
<lifecycle>
<phase-listener>lst.PhaseListener</phase-listener>
</lifecycle>
V. Tecnologías Java EE

JSF Paso a Paso
 Mapear Componentes
 Mapear Valores Fijos


<h:outputText value=“Hola Mundo !!"/>
Mapear Propiedades del Sistema



Con Objetos
<h:outputText value=“#{initParam.version}"/>
<h:outputText value=“#{param[‘nombre’]}"/>
Mapear Propiedades de un Bean Manejado


Siguen convenciones JavaBean.
<h:outputText value="#{managedBeans.propiedad}"/>
<managed-bean>
<managed-bean-name>managedBeans</managed-bean-name>
<managed-bean-class>mbeans.ManagedBeans</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
<managed-property>
<property-name>propiedad</property-name>
<value>Hola Mundo !!</value>
</managed-property>
</managed-bean>
V. Tecnologías Java EE

JSF Paso a Paso
 Mapear

Componentes
Mapear Componentes Completos Backing Beans

<h:outputText binding="#{managedBeans.component}"/>
package mbeans;
import javax.faces.component.UIOutput;
public class ManagedBeans {
private UIOutput component;
public void setComponent(UIOutput ui) {
component = ui;
component.setValue("Hola Mundito !!");
}
public UIOutput getComponent() { return component; }
}
V. Tecnologías Java EE

JSF Paso a Paso
 Invocar

Métodos
Métodos de Validación
Utilizados sólo en UIInput.
 Reciben el FacesContext y el componente a validar y su
valor.

<h:messages/>
<h:inputText validator="#{managedBeans.validateEmail}"/>
public void validateEmail(FacesContext ctx, UIComponent cmp,
Object obj) {
String email = (String)obj;
if (email.indexOf("@")<0) {
((UIInput)cmp).setValid(false);
ctx.addMessage(cmp.getClientId(ctx),
new FacesMessage("Mail Incorrecto", ""));
} else ((UIInput)cmp).setValid(true);
}
V. Tecnologías Java EE

JSF Paso a Paso
 Invocar

Métodos
Manejadores de Acciones
Se utiliza en UICommand y UIButton.
 Reciben el evento.

<h:commandButton value="Pulsa" actionListener="#{managedBeans.ejecutaAccion}“/>
public void ejecutaAccion(ActionEvent ev) {
System.out.println("Se ejecuta la acción !!");
}
V. Tecnologías Java EE

JSF Paso a Paso
 Invocar

Métodos
Manejadores de Navegación
Se utiliza en UICommand y UIButton.
 Retornan una cadena de navegación.

<h:commandLink value="Pincha" action="#{managedBeans.onlyAction}“/>
public String onlyAction() {
return “success";
}
V. Tecnologías Java EE

JSF Paso a Paso
 Invocar

Métodos
Manejadores de Cambios

Capturar cambios sobre componentes UIInput.
<h:selectBooleanCheckbox
valueChangeListener="#{managedBeans.changeColor}"
onchange="submit()"/>
public void changeColor(ValueChangeEvent event) {
boolean flag = ((Boolean)event.getNewValue()).booleanValue();
System.out.println("Check: "+flag);
}
V. Tecnologías Java EE

JSF Paso a Paso
 Controlar
Navegación
Conjunto de reglas para seleccionar la siguiente
página a la que moverse.
 La selección depende de:

Página actual.
 Action ejecutado por el componente que navega.
 Cadena retornada por el action (outcome).


Admite patrones en from-view-id.
<navigation-rule>
<from-view-id>/logon.jsp</from-view-id>
<navigation-case>
<from-action>#{LogonForm.logon}</from-action>
<from-outcome>success</from-outcome>
<to-view-id>/continue.jsp</to-view-id>
</navigation-case>
</navigation-rule>
V. Tecnologías Java EE

JSF Paso a Paso

Controlar Navegación. Ejemplos.
<navigation-rule>
<from-view-id>/pages/logon.jsp</from-view-id>
<navigation-case>
<from-outcome>success</from-outcome>
<to-view-id>/continue1.jsp</to-view-id>
</navigation-case>
<navigation-case>
<from-action>#{m.acc}</from-action>
<from-outcome>success</from-outcome>
<to-view-id>/continue2.jsp</to-view-id>
</navigation-case>
</navigation-rule>
<navigation-rule>
<from-view-id>/pages/*</from-view-id>
<navigation-case>
<from-outcome>success</from-outcome>
<to-view-id>/continue3.jsp</to-view-id>
</navigation-case>
</navigation-rule>
<navigation-rule>
<navigation-case>
<from-outcome>error</from-outcome>
<to-view-id>/error.jsp</to-view-id>
</navigation-case>
</navigation-rule>
Enlace en /pages/logon.jsp
Destino
<h:commandButton action=“success" value="Submit" />
continue1.jsp
<h:commandButton action=“#{m.acc}" value="Submit" />
continue2.jsp
<h:commandButton action=“error" value="Submit" />
error.jsp
Enlace en /pages/otra.jsp
Destino
<h:commandButton action=“success" value="Submit" />
continue3.jsp
<h:commandButton action=“#{m.acc}" value="Submit" />
continue3.jsp
<h:commandButton action=“error" value="Submit" />
error.jsp
V. Tecnologías Java EE

JSF Paso a Paso
 Crear
el adivinador de números JSF.
Crear un bean para calcular el número aleatorio.
 El mismo bean puede recoger el número
introducido.
 Crea el JSP para solicitar el número, valida la
entrada con validateLongRange.
 Configura la navegación adecuada.

V. Tecnologías Java EE

Crea un Hola Mundo JSF.
V. Tecnologías Java EE

Crea un Hola Mundo JSF.
V. Tecnologías Java EE

JSF Paso a Paso
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
<%@
taglib prefix="f" uri="http://java.sun.com/jsf/core"%>
Internacionalizar
i18n
<%@ taglib prefix="h" uri="http://java.sun.com/jsf/html"%>
<!DOCTYPE
html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<application>
<html><locale-config>
<managed-bean>
<head>
public
class
Adivina
{
<default-locale>es</default-locale>
<managed-bean-name>adivina</managed-bean-name>
<%@
language="java" contentType="text/html;
<metapage
http-equiv="Content-Type"
content="text/html; charset=ISO-8859-1"
charset=ISO-8859-1">pageEncoding="ISO-8859-1"%>
<supported-locale>en</supported-locale>
<managed-bean-class>mbeans.Adivina</managed-bean-class>
<%@
taglib
prefix="f"
uri="http://java.sun.com/jsf/core"%>
<title>Insert
title here</title>
private
long numeroPensado;
</locale-config>
<%@
taglib<managed-bean-scope>session</managed-bean-scope>
prefix="h"
uri="http://java.sun.com/jsf/html"%>
</head>
private
int numero;
<message-bundle>msg.mensajes</message-bundle>
<managed-property>
<!DOCTYPE
html
PUBLIC
"-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<body>
private int minimo;
<resource-bundle>
<property-name>minimo</property-name>
<html>
<f:view> private
int maximo;
<base-name>msg.mensajes</base-name>
<value>1</value>
<head>
<h:outputText
rendered="#{adivina.intentado}" value="Lo siento, vuelve a probar !!"/>
<var>msg</var>
</managed-property> content="text/html; charset=ISO-8859-1">
<meta http-equiv="Content-Type"
He pensado
número entre <h:outputText
value="#{adivina.minimo}"/>
y
public
Adivina()un{ numeroPensado
= Math.round(Math.random()*10);
}
</resource-bundle>
<title>Insert<managed-property>
title
here</title>
<h:outputText
value="#{adivina.maximo}"/>,
adivina !!
public int getNumero()
{ return numero; }
</application>
<property-name>maximo</property-name>
</head>
<h:form>
public void setNumero(int
n) { numero = n; }
<value>10</value>
<body>
<h:messages
showDetail="true"/>
<f:loadBundle
basename="msg.mensajes"
var="msg"/>
public
int
getMinimo()
{
return
minimo;}
</managed-property>
<f:view>
<h:selectOneMenu
onchange="submit()"
<h:messages
showDetail=“true”
showSummary=“true”/>
public void setMinimo(int minimo) { this.minimo = minimo; }
</managed-bean>
Has
acertado,
era el <h:outputText
value="#{adivina.numero}"/>
!!
valueChangeListener="#{adivina.cambiaIdioma}"
immediate="true">
<h:outputText
value="#{msg.titulo}"/>
public
int getMaximo()
{ return maximo;
}
<navigation-rule>
</f:view> public void setMaximo(int
<f:selectItemmaximo)
itemLabel="#{msg.castellano}"
{this.maximo = maximo;itemValue="es"/>
}
<from-view-id>/index.jsp</from-view-id>
</body>
<f:selectItem
itemLabel="#{msg.ingles}"
itemValue="en"/>
Archivo public
de
Propiedades:
msg/mensajes.properties,
msg/mensajes_en.properties,
…
String adivinar() { return (numeroPensado==numero)? "success“:"fail"; }
<navigation-case>
</html>
</h:selectOneMenu>
public boolean
isIntentado() { return numero!=0; }
<from-outcome>success</from-outcome>
<h:inputText
value="#{adivina.numero}">
publicen
void
event) {
titulo=Pienso
un cambiaIdioma(ValueChangeEvent
número
entre
<to-view-id>/next.jsp</to-view-id>
<f:validateDoubleRange
minimum="#{adivina.minimo}"
FacesContext.getCurrentInstance().getViewRoot().setLocale(newmaximum="#{adivina.maximo}"/>
Locale((String)event.getNewValue()));
</navigation-case>
javax.faces.validator.DoubleRangeValidator.NOT_IN_RANGE=Sumario
</h:inputText>
//
Cortocircuito
!!
<navigation-case>
javax.faces.validator.DoubleRangeValidator.NOT_IN_RANGE_detail=Valor
fuera de rango {0} - {1}.
<h:commandButton value="Prueba" action="#{adivina.adivinar}"/>
FacesContext.getCurrentInstance().renderResponse();
<from-outcome>fail</from-outcome>
</h:form>
}
<to-view-id>/index.jsp</to-view-id>
</f:view>
}
</navigation-case>
</body>
</navigation-rule>
</html>
 Crear
el adivinador de números JSF.
V. Tecnologías Java EE

Facelets


Complemento ideal para JSF.
Definir una plantilla para tu portal y emplearla en todas tus
páginas.
<ui:include src=“cabecera.xhtml”/>
<ui:insert name=“body”/>
/pagina.xhtml
<ui:composition template=“/plantilla.xhtml”>
<ui:include
src=“menu.xhtml”/>
<ui:define name=“body”>
…
</ui:define>
</ui:composition>
<ui:include src=“pie.xhtml”/>
V. Tecnologías Java EE

Crea una plantilla facelets.
Añadir la librería Facelets:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
jsf-facelets-1.1.15.B1.jar
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
Nota: web.xml
y faces-config.xml
modifica
eclipse
Debemos
cambiarloslas
vistas
y las!! reglas
del
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:ui="http://java.sun.com/jsf/facelets"
faces-config.xml los
id de las vistas pasan de
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core">
<f:view contentType="text/html"/>
.jsp a .xhtml.
<head>
<meta http-equiv="Content-Type" content="text/xhtml+xml; charset=UTF-8" />
<title>Simple JSF</title>
<link href="stylesheet/theme.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="content">
<div id="header"><ui:include src="header.xhtml" /></div>
<div id="menu" style="float:left;width:200px;"><ui:include src="menu.xhtml" /></div>
<div id="body" style="float:left;"><ui:insert name="body" >Default Content</ui:insert></div>
<div id="footer"><ui:include src="footer.xhtml" /></div>
</div>
</body>
</html>
V. Tecnologías Java EE

Usar RichFaces.
<!-- RichFaces en web.xml -->
<context-param>
<param-name>org.richfaces.SKIN</param-name>
<param-value>blueSky</param-value>
Para Usar RichFaces
Añadir Librerías:
</context-param>
<!-- RichFaces + Facelets -->
commons-beanutils-1.7.0.jar
<context-param>
<?xml version="1.0" encoding="UTF-8"?>
<param-name>org.ajax4jsf.VIEW_HANDLERS</param-name>
commons-digester-1.8.jar
<html … xmlns:a4j="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich">
<param-value>com.sun.facelets.FaceletViewHandler</param-value>
<body bgcolor="white">
</context-param>
commons-logging-1.1.1.jar
…
<filter>
<rich:panel id="panelRoot" >
<display-name>RichFaces Filter</display-name>
richfaces-api-3.3.1.GA.jar
<rich:spacer height="5" title="Here is a spacer..."/><br />
<filter-name>richfaces</filter-name>
<rich:separator lineType="beveled" height="8" width="100%" align="center"/>
<filter-class>org.ajax4jsf.Filter</filter-class>
richfaces-impl-3.3.1.GA.jar
<rich:separator height="2" lineType="dotted"/><br />
</filter>
</rich:panel>
<filter-mapping>
richfaces-ui-3.3.1.GA.jar
…
<filter-name>richfaces</filter-name>
</body>
Servlet</servlet-name>
Nota:
Hay que configurar <servlet-name>Faces
a mano !!
</html>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
Y muchos componentes más: RichFaces Live Demo.
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
<listener>
<listener-class>com.sun.faces.config.ConfigureListener</listener-class>
</listener>
<!-- Ya no es necesario modificar faces-config.xml -->
<!-- application>
<view-handler>com.sun.facelets.FaceletViewHandler</view-handler>
</application -->
V. Tecnologías Java EE

Tecnologías Control: EJB




Dar más servicios a los objetos empleados en las aplicaciones web.
Contenedor específico para desplegar y ejecutar este tipo de objetos.
Posibilidad de compartir lógica a través de estos objetos.
Necesario un Contenedor de EJB. Servidor JEE.
V. Tecnologías Java EE

Tecnologías Control: EJB

Tipos de EJB

Session Beans: Sitos en la lógica de negocio.




Stateless: Sin información de estado.
Stateful: Mantienen el estado entre peticiones.
Message Driven Beans: Utilizados para invocar métodos de forma
asíncrona.
Entity Beans: Empleados en la capa de persistencia para
representar datos del modelo.
V. Tecnologías Java EE

Tecnologías Control: EJB

Ciclo de Vida

Creación, Destrucción, Pasivación (Stateful).
V. Tecnologías Java EE

Tecnologías Control: EJB
 Callbacks
 Siempre que tenemos un ciclo de vida.
 Posibilidad de emplear AOP.




@PostConstruct
@PreDestroy
@PreActivate
@PostActivate
 Interceptores
 Siempre que empleamos contenedores IoC y Ciclos de Vida.
 Posibilidad de emplear AOP.



Default
Clase
Método
V. Tecnologías Java EE

Tecnologías Control: EJB
 Anotaciones.

Forma de simplificar la definición del EJB.


@Stateful
@Stateless
@Stateless
public class PlaceBidBean implements PlaceBid {
@Interceptors(ActionBazaarLogger.class)
public void addBid(Bid bid) {
...
}
}
public class ActionBazaarLogger {
@AroundInvoke
public Object logMethodEntry(InvocationContext invocationContext) throws Exception {
System.out.println(”Entering: ”+ invocationContext.getMethod().getName());
return invocationContext.proceed();
}
}
V. Tecnologías Java EE

Prácticas II
 Crea
un proyecto EJB.
 Liga tu proyecto EJB a una aplicación Web.
 Emplea los EJB’s creados desde la aplicación Web.
 Crea los EJB necesarios para Diario Digital.
V. Tecnologías Java EE

Crea un proyecto EJB.
V. Tecnologías Java EE

Crea un EJB.
@Stateless
public class Ejemplo implements EjemploLocal {
double numero;
public Ejemplo() {
System.out.println("Stateless!!!");
numero = Math.floor(Math.random()*10+1);
}
@Override
public String getMensaje() {
numero++;
return "Mensaje ["+numero+"]";
}
}
@Stateful
public class EjemploB implements EjemploBLocal {
double numero;
public EjemploB() {
System.out.println("Stateful!!!");
numero = Math.floor(Math.random()*10+1);
}
@Override
public String getMensaje() {
numero++;
return "MensajeB ["+numero+"]";
}
}
public class JSFBean {
@EJB
Faces-config.xml
public EjemploBLocal ejemplo;
-------------------------------------------------------------------------------------public String getMensaje() { return ejemplo.getMensaje(); } <managed-bean>
}
<managed-bean-name>jSFBean</managed-bean-name>
<managed-bean-class>mb.JSFBean</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
</managed-bean>
Página
-------------------------------------------------------------------------------------<h:outputText value="#{jSFBean.mensaje}" />
V. Tecnologías Java EE

Crea un EJB.
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Muchos

proyectos diferentes ORM.
IBatis, Hibernate, JDO, TopLink,…
 Necesario
unificar: JPA.
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Contextos
de Persistencia
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
version="1.0">
<persistence-unit name="defaultPU" transaction-type="JTA">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>jdbc/NombreDataSource</jta-data-source>
<properties>
<property name="hibernate.hbm2ddl.auto" value="validate"/>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true"/>
<property name="hibernate.default_shema" value="NOMBRE"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/>
<property name="hibernate.transaction.manager_lookup_class“
value="org.hibernate.transaction.OC4JTransactionManagerLookup"/>
<property name="hibernate.query.factory_class“ value="org.hibernate.hql.classic.ClassicQueryTranslatorFactory" />
<property name="hibernate.transaction.flush_before_completion" value="true"/>
<property name="hibernate.cache.provider_class“ value="org.hibernate.cache.HashtableCacheProvider"/>
</properties>
</persistence-unit>
</persistence>
Transacciones JTA: Empleada en Servidores de Aplicaciones JavaEE
Transacciones RESOURCE_LOCAL: Empleada en Aplicaciones C/S.
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Empleo

de Persistencia
Declarar un EntityManager ligado a la Unidad que necesites.
public @Stateful class NoticiasBean implements Noticias,Serializable {
@PersistenceContext(unitName="diarioPU")
protected EntityManager entityManager;
private List<Noticia> listado;
public List<Noticia> getListado() {
listado = entityManager.createQuery("from noticias.Noticia noti").getResultList();
return listado;
}
public void nuevaNoticia(Noticia not) { entityManager.persist(not); }
}
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Ciclo
de Vida: Entity Beans
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Anotaciones
Básicas: Entidades y Claves
@Entity
public class Entidad {
@EmbeddedId
@AttributeOverrides({
@AttributeOverride(name = "id", column = @Column(name = "ID",
nullable = false, precision = 5, scale = 0)),
@AttributeOverride(name = "nombre", column = @Column(name =
"NOMBRE", nullable = false, length = 50)),
})
private EntidadId id;
public Entidad() { }
// Getters y Setters
}
@Embedded
public class EntidadId {
int id;
String nombre;
public EntidadId() { }
public boolean equals(Object o) { /* Comprueba si son iguales */ }
public int hashCode() { /* Buenas practicas equals() -> hashCode() */ }
}
Clave Simple
@Entity
@Table(name="USUARIOS")
public class Usuario {
@Id
private String nick;
...
public Usuario() { }
// Getters y Setters
}
Clave Compuesta
V. Tecnologías Java EE

Tecnologías Modelo: JPA
 Anotaciones
Básicas: Atributos
@Entity
@Table(name="USUARIOS")
public class Usuario {
@Id
private String nick;
@Embedded
@AttributeOverrides({
@AttributeOverride(name="codigoPostal",column=@Column(name="COD_POS")),
@AttributeOverride(name="direccionPostal",column=@Column(name="DIR_POS"))
})
private Direccion direccion;
public Usuario() { }
// Getters y Setters
}
@Embeddable
public class Direccion implements Serializable {
private String direccionPostal;
private String ciudad;
private int codigoPostal;
private String pais;
public Direccion() { }
public boolean equals(Object o) { /* Comprueba si las dos entidades son iguales */ }
public int hashCode() { /* Buenas practicas equals() -> hashCode() */ }
// Getters y Setters
}
Atributo Simple
@Entity
@Table(name="USUARIOS")
public class Usuario {
@Id
private String nick;
@Column(name="PASSWORD", nullable=false)
private String pass;
@Column(name="E-MAIL", nullable=false)
private String mail;
@Lob
@Basic(fetch=FetchType.LAZY)
private byte[] imagen;
...
public Usuario() { }
// Getters y Setters
}
Atributo Compuesto
V. Tecnologías Java EE

Tecnologías Modelo: JPA
@Entity
@Table(name="PERFILES")
public class Perfil {
@Entity
@Id
@Table(name="USUARIOS")
@Column(name="PERFIL_ID")
public class Usuario {
private int id;
@Id
CascadeType.PERSIST: Cuando persistamos la entidad todas las...entidades que
private String nick;
contenga esta variable
serán persistidas también.
}
@Column(name="PASSWORD",
nullable=false)
CascadeType.REMOVE:
Cuando
borremos
la
entidad
todas
las
entidades
que
private String pass;
@OneToOne
contenga esta variable se borrarán del mismo modo.
@JoinColumn(name="PERFIL_USUARIO_ID",referencedColumnName="PERFIL_ID",
CascadeType.REFRESH: Cuando actualicemos la entidad todasupdatable=false)
las entidades que
private Perfil
perfil;
contenga esta variable se actualizarán.
private Set<Noticia> noticias = new HashSet<Noticia>(0);
CascadeType.MERGE: Cuando hagamos un "merge" de la entidad todas las
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY,mappedBy = "usuario")
entidades
que contenga
esta variable realizarán la misma operación.
public Set<Noticia>
getNoticias()
{
CascadeType.ALL:
Todas las operaciones
@Entity citadas anteriormente.
return this.noticias;
@Table(name = "NOTICIA")
}
public class Noticia implements java.io.Serializable {
public void setNoticias(Set<Noticia> noticias) {
...
this.noticias = noticias;
private Usuario usuario;
}
@ManyToOne(fetch = FetchType.LAZY)
...
@JoinColumn(name = "USUARIO", nullable = false)
}
@NotNull
public Usuario getUsuario() { return this.usuario; }
ManyToMany: Muy similar a ManyToOne
public void setUsuario(Usuario usuario) { this.usuario = usuario; }
pero simétrica en ambas clases.
...
ManyToOne }

Anotaciones Básicas: Relaciones OneToOne
V. Tecnologías Java EE

Tecnologías Modelo: JPA

Anotaciones Avanzadas: Querys Personalizadas
@NamedNativeQuery (
name="nativeResult",
query="SELECT USUARIO_ID,NOMBRE,APELLIDOS FROM USUARIOS WHERE USUARIO_ID= 123",
resultSetMapping = "usuarioNamedMapping")
@SqlResultSetMapping (
name="usuarioNamedMapping",
entities = { @EntityResult (
entityClass = mi.clase.Usuario.class,
fields = {@FieldResult (
name="usuarioId",
column="USUARIO_ID"),
@FieldResult (
name="nombre",
column="NOMBRE"),
@FieldResult (
name="apellidos",
column="APELLIDOS")
})
})
V. Tecnologías Java EE

Tecnologías Modelo: JPA

Anotaciones Avanzadas: Procedimientos Almacenados
create or replace procedure findUsersLike(res out sys_refcursor, str in string) as
begin
open res for select u.* from users u where u.username like concat(str, '%');
end findUsersLike;
@NamedNativeQuery (name = "User.findLike",
resultClass = User.class,
query = "{call findUsersLike(?,:VAR)}",
hints = {
@QueryHint(name = "org.hibernate.callable", value = "true"),
@QueryHint(name = "org.hibernate.readOnly", value = "true")
}
)
@org.hibernate.annotations.NamedNativeQuery (name=“User.findLike”,
resultClass = User.class,
query = "{call findUsersLike(?,:VAR)}",
callable = true, readOnly = true)
Query query = em.createNamedQuery("User.findLike");
query.setParameter("VAR","lt");
List users = query.getResultList();
V. Tecnologías Java EE

Aplicación Completa: JSF+EJB3+JPA
 Emplear
EJB Session Bean Facade.
V. Tecnologías Java EE

Prácticas III
 Crea
un ejemplo de Bean de Entidad.
 Incluye atributos de diferentes tipos.
 Relaciona varias entidades.
 Convierte los objetos del Diario Digital en
entidades JPA para dotarlas de persistencia.
V. Tecnologías Java EE

Crea un ejemplo de Bean de Entidad.
V. Tecnologías Java EE

Crea un ejemplo de Bean de Entidad.
V. Tecnologías Java EE

Crea un ejemplo de Bean de Entidad.
V. Tecnologías Java EE

Crea un ejemplo de Bean de Entidad.
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="DiarioJPA" transaction-type="JTA">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<jta-data-source>DiarioDataSource</jta-data-source>
<non-jta-data-source>DiarioDataSource</non-jta-data-source>
<class>data.Categoria</class>
<class>data.Noticia</class>
<properties>
<property name="eclipselink.target-server" value="WebLogic_10"/>
<property name="eclipselink.logging.level" value="FINEST"/>
</properties>
</persistence-unit>
</persistence>
VI. Tecnologías
Avanzadas
VI. Tecnologías Avanzadas

Servicios WEB
 Forma
de interactuar.
VI. Tecnologías Avanzadas

Servicios WEB
 Buscar

Catálogo de Servicios.
 Invocar

servicios Web: UDDI.
Servicios Web: WSDL.
Descriptor del Servicio.
 Intercambio

Documentos XML.
 Las


de Información: SOAP.
herramientas nos simplifican el trabajo.
A partir de un método podemos crear un servicio.
A partir de un WSDL podemos crear un cliente.
VI. Tecnologías Avanzadas

Servicios WEB
 Implementaciones
Diversas: Tratan de
automatizar la creación de servicios y
clientes.
Axis2
 JAXWS
 CXF

 Usaremos
JAXWS.
 En FundeWeb se usará CXF, pero el curso se
centra en la interacción y no en las
implementaciones.
VI. Tecnologías Avanzadas

Prácticas I
 Crea
un Sencillo Servicio Web.
 Pruébalo con el “Web Service Explorer”
 Genera un cliente a partir del WSDL.
 Crea el Servicio Web “Teletipo”.
 Incluye en el Diario Digital las noticias del
“Teletipo”.
VI. Tecnologías Avanzadas

Crea un Sencillo Servicio Web.
VI. Tecnologías Avanzadas

Crea un Sencillo Servicio Web.
http://localhost:7001/DiarioWS/TitularesService?WSDL
@WebService
public class Titulares {
@EJB
private NoticiasLocal misNoticias;
@WebMethod
public List<Titular> listTitulares() {
ArrayList<Titular> lista = new ArrayList<Titular>();
for (Noticia n:misNoticias.getListadoPortada()) {
Titular t = new Titular();
t.setTitulo(n.getTitulo()); t.setFecha(n.getDia());
lista.add(t);
}
public class Titular implements Serializable {
return lista;
private String titulo;
}
private Date fecha;
}
public String getTitulo() { return titulo; }
public void setTitulo(String titulo) { this.titulo = titulo; }
public Date getFecha() { return fecha; }
public void setFecha(Date fecha) { this.fecha = fecha; }
}
http://localhost:7001/wls_utc/?wsdlUrl=http://localhost:7001/DiarioWS/TitularesService?WSDL
VI. Tecnologías Avanzadas

Crea un Sencillo Servicio Web.
public List<Titular> getTitulares() {
TitularesService ts = new TitularesService();
return ts.getTitularesPort().listTitulares();
}
VI. Tecnologías Avanzadas

Autenticación JAAS

Java EE permite emplear roles para securizar recursos de una
aplicación.
<security-role>
<role-name>administrador</role-name>
</security-role>
<security-role>
<role-name>usuario</role-name>
</security-role>
<orion-application …>
...
<jazn provider="XML" location="./jazn-data.xml" default-realm="example.com">
<property name="jaas.username.simple" value="false"/>
</jazn>
</orion-application>
<jazn-data
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://xmlns.oracle.com/oracleas/schema/jazn-data-10_0.xsd" filepath="" OC4J_INSTANCE_ID="">
<jazn-realm>
<realm>
<name>example.com</name>
<users><user><name>admin</name><credentials>!admin</credentials></user></users>
<roles>
<role><name>administrador</name><members><member><type>user</type><name>admin</name></member></members></role>
</roles>
</realm>
</jazn-realm>
</jazn-data>
VI. Tecnologías Avanzadas

Autenticación JAAS

Java EE permite emplear roles para securizar recursos de una
aplicación.
@DeclareRoles({"administrador", "usuario"})
public class Ejemplo extends HttpServlet {
protected void service(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
if (req.isUserInRole("administrador")) {
// El usuario Autenticado tiene el rol administrador
}
}
}
<security-constraint>
<web-resource-collection>
<web-resource-name>Permiso Ejemplo</web-resource-name>
<url-pattern>/Ejemplo</url-pattern>
<http-method>GET</http-method>
<http-method>POST</http-method>
</web-resource-collection>
<auth-constraint>
<role-name>administrador</role-name>
</auth-constraint>
<user-data-constraint>
<transport-guarantee>NONE</transport-guarantee>
</user-data-constraint>
</security-constraint>
<!-- LOGIN CONFIGURATION-->
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
VI. Tecnologías Avanzadas

Prácticas II
 Crea
roles en una aplicación.
 Añade seguridad a diferentes recursos.
 Securiza la creación de noticias en el Diario
Digital.
VI. Tecnologías Avanzadas

Crea roles en una aplicación.
<!-- ROLES DE SEGURIDAD -->
<security-role>
<role-name>redactor</role-name>
<wls:security-role-assignment>
</security-role>
<wls:role-name>redactor</wls:role-name>
<security-role>
<wls:principal-name>Administrators</wls:principal-name>
<role-name>usuario</role-name>
</wls:security-role-assignment>
</security-role>
<wls:security-role-assignment>
<security-constraint>
<wls:role-name>usuario</wls:role-name>
<web-resource-collection>
<web-resource-name>Redaccion del Diario</web-resource-name>
<wls:principal-name>AppTesters</wls:principal-name>
<url-pattern>/editar/*</url-pattern>
</wls:security-role-assignment>
<http-method>GET</http-method>
<http-method>POST</http-method>
</web-resource-collection>
<auth-constraint>
<role-name>redactor</role-name>
</auth-constraint>
<user-data-constraint>
<transport-guarantee>NONE</transport-guarantee>
</user-data-constraint>
</security-constraint>
<!-- LOGIN CONFIGURATION-->
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
VI. Tecnologías Avanzadas

Portales y Portlets
 Idea
similar a la de los servlets.
 Componentes configurables y reubicables.
 Pensados para su uso en portales.
 Especificación JSR 168.
VI. Tecnologías Avanzadas

Portales y Portlets
 Ventajas
Desarrollo independiente y reutilizable.
 Personalización dinámica.
 Seguridad ante fallos. El fallo de un portlet no
afecta al resto del portal.
 Adoptado por otras tecnologías. PHP Portlet.

 Inconvenientes
Tecnología relativamente nueva.
 Genera portales con poca personalidad.

A. Diario Digital
A. Diario Digital

Práctica Global
 Muestra
las noticias de un diario y un teletipo.
EAR Application
WEB Module
WEB Module
JSF Application
EJB Module
Web Service
JSF Application
Database
¡ Gracias !