Está en la página 1de 16

Programando Soluciones

En JSP existe una forma muy practica de programar usando el patrón MVC
(modelo-vista-controlador), donde se separan aun mas las capas, no es la
intención explicar el patrón MVC, sino explicar su aplicación en JSP.

En mi corta experiencia he visto varias formas de aplicar este patrón a aplicaciones


de las cuales he hecho mi propia implementación utilizando cosas de la una y de la
otra.

Modelo Vista Controlador


- Beans - Paginas - Controller
- Action JSP/HML
- Actions
- Model
- WebModel

Programando Soluciones
Las clases que interviene las representamos en el siguiente diagrama
- Bean Departamento
- Bean Empleado
- Model utiliza a Empleado
- Model utiliza a Departamento
- WebModel extiende de Model
- Action utiliza a Model
- AgregarEmpleado es una Action
- AgregarDepartamento es una Action
- Controller utiliza a Action (o cualquier clase
que extiende de ella)

Programando Soluciones
La manera en que inicia la aplicación

web.xml InitModel.jsp index.jsp

•Guarda la • Carga la • Carga a


configuración configuración de InitModel.jsp
para conectarse la BD y se
a la base de conecta.
datos. • Inicializa
•Guarda la (controller, baseurl,
configuración absoluteurl).
(mapeo) del
servlet.

Programando Soluciones
La manera de interactuar de la aplicación es
1. Al ocurrir un evento, este
(dependiendo, de los parámetros
de mapeo) será direccionado al
pagina.jsp Controller.
2. El Controller cargará la Action
• Muestra información . correspondiente seteará y
• Llamado a servlets. ejecutará.
3. La Action se ejecuta y re-
direcciona a una pagina o en
1 algunos casos a otro Action.
3

Controller.class Action.class

• Atender y re-direccionar los • Encapsular los métodos


llamados a un Action.
2 necesarios para permitir
• Buscar en memoria o seteo de parámetros (como
cargar en memoria las servlet).
3
Actions • Encapsular los métodos
necesarios para permitir
ejecución (doGet, doPost)
•Re-direccionar.

Programando Soluciones
La manera de interactuar de la aplicación es

index.jsp

•Carga la información de la
configuración.
• Incluye las otras paginas.
1 •Hace los llamados
RegistarDepartamento y 3
RegistrarEmpleado.

Controller RegistarDepartamento
RegistrarEmpleado
• Atender y re-direccionar los
llamados a un
2 • Realizan una operación.
RegistarDepartamento y •.Re-direccional la pagina al
RegistrarEmpleado.. index.
• La primera vez los
inicializa, la segunda los
busca en memoria.

Programando Soluciones
El archivo de configuración web.xml

El tipo de XML

<?xml version="1.0" encoding="ISO-8859-1"?>

<!DOCTYPE web-app
PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd">

La configuración realmente se encuentra dentro de las etiquetas

<web-app> y </web-app>

Nombre y descripción solo etiquetas informativas

<display-name>EJERCICIO 13 MODELO-VISTA-CONTROLADOR</display-name>
<description> XML de configuración para aplicar el patrón MVC en jsp</description>

Programando Soluciones
El archivo de configuración web.xml

Los parámetros o variables de contexto

<context-param> (declaramos un parámetro/variable de contexto )


<param-name>nombre</param-name> (le damos un nombre)
<param-value>valor</param-value> (le damos un valor)
</context-param> (cerramos la declaración)

De la forma anterior declaramos 5 parámetros


• JdbcDriver = com.mysql.jdbc.Driver;
• databaseURL= jdbc:mysql://localhost:3306/ejercicios;
• databaseUser= root;
• databaseKey=;
• ABSOLUTEURL = http://localhost:8181/ejercicio13/;

Los parametros los usamos para:


• JdbcDriver = la clase driver que usaremos para conectarnos a la BD;
• databaseURL= URL de la base de datos;
• databaseUser= nombre de usuario a la base de datos;
• databaseKey=; clave para la base de datos
• ABSOLUTEURL = dirección a nuestra aplicación;

Programando Soluciones
El archivo de configuración web.xml

Los parámetros o variables de contexto

<context-param> (declaramos un parámetro/variable de contexto )


<param-name>nombre</param-name> (le damos un nombre)
<param-value>valor</param-value> (le damos un valor)
</context-param> (cerramos la declaración)

De la forma anterior declaramos 5 parámetros


• JdbcDriver = com.mysql.jdbc.Driver;
• databaseURL= jdbc:mysql://localhost:3306/ejercicios;
• databaseUser= root;
• databaseKey=;
• ABSOLUTEURL = http://localhost:8181/ejercicio13/;

Los parametros los usamos para:


• JdbcDriver = la clase driver que usaremos para conectarnos a la BD;
• databaseURL= URL de la base de datos;
• databaseUser= nombre de usuario a la base de datos;
• databaseKey=; clave para la base de datos
• ABSOLUTEURL = dirección a nuestra aplicación;

Programando Soluciones
El archivo de configuración web.xml

Definición y mapeo del servlet

Esto hace referencia a la configuración del servlet quien responderá los llamados a los servlets

<servlet>(abrimos la etiqueta para describir un servlet)


<servlet-name>controlador</servlet-name>(que llamaremos controlador)
<servlet-class>org.Controller</servlet-class>(y la clase es org.Controller)
</servlet>(cerramos definicion del servlet)

<servlet-mapping>(el mapeo del servlet)


<servlet-name>controlador</servlet-name>(el servlet que se llama controlador)
<url-pattern>/servlet/*</url-pattern>(responderá los llamados que tengan esta estructura /servlet/*)
</servlet-mapping>(cerramos mapeo del servlet)

O sea que nuestro servlet responderá cualquier url a la que llamemos que tenga
algo_aqui/servlet/cualquier_cosa_aqui

Programando Soluciones
InitModel.jsp

Inicializando la conexión a la BD

<jsp:useBean id="model" scope="session" class="org.WebModel">


<%model.init(application);%>
</jsp:useBean>

1. Declaramos un bean de tipo WebModel que se llama modelo y que solo será visto en la session.
2. Dicho bean hereda de Model, pero tiene métodos para que funcione en entorno web (será capaz de
sacar los parámetros que declaramos en el web.xml).

<%
String BASEURL=request.getContextPath();(sacamos la URL base en este caso “/ejercicio13”)
String CONTROLLER=BASEURL+"/servlet“;(para los servlets en este caso “/ejercicio13/servlet”)
String ABSOLUTEURL=application.getInitParameter("ABSOLUTEURL");
(ABSOLUTEURL en este caso será http://localhost:8181/ejercicio13/)

(Los guardamos para que puedan ser vistos pr toda la aplicación)


application.setAttribute("CONTROLLER",CONTROLLER);
application.setAttribute("BASEURL",BASEURL);
application.setAttribute("ABSOLUTEURL",ABSOLUTEURL);
%>
Programando Soluciones
LA PARTE JAVA

Controller.java

Controller específicamente es un servlet, con 3 métodos

doPost(): se ejecuta cuando en el formulario que lo llama el method=“post”, este método invoca al método
ejecutar().

doGet(): se ejecuta cuando en el formulario que lo llama el method=“get” o cuando es llamado por medio
de un enlace, este método invoca al método ejecutar().

ejecutar(): ejecutar en algunas convecciones doRequest() o run(), este método tiene que cargar a la acción
especifica que se quiere invocar.

En la session se van guardando las acciones a medida que se van cargando.

Programando Soluciones
LA PARTE JAVA

Controller.java
/*llamamos a la session*/ /*guardamos el mapa de acciones en la session*/
/*sacamos el mapa de acciones de la session*/ /*si no se encontro la clase*/
/*si aun no exite*/ /* o no se pudo instansiar la clase*/
/*lo inicializamos*/ /*o hubo un acceso no autorizado*/
/*Sacamos el contexto de la aplicacion*/ /*lanza una excepcion*/
/* obtenemos la ruta (Accion) a ejecutar*/ /*sacamos el model de la session*/
/*si la ruta es null*/ /*si el model == null*/
/*lanzamos una exception*/ /*lanza una excepcion*/
/*declaramos una accion, y la cargamos de mapa de acciones*/ /*seteamos los parámetros de la accion*/
/*si la accion no se encuentra en el mapa*/ /*y la ejecutamos*/
/* la ruta viene en el formato "Accion/Bean" */ /*atrapamos cualquier excepcion */
/* la ruta viene en el formato "Palabra1/Palabra2" */ /*Pasamos el mensaje a una ServletException*/
/*dividimos la ruta en 2 justo por el caracter '/' */
/*si el numero de partes es diferente de 2 hubo algún error */ Para tener una idea mas clara mirar los
/*lanzamos una excepcion*/
/*tenemos la parte uno de la Accion */
comentarios en la clase
/*tenemos la parte dos de la Accion */
/*nombre de la clase de la Accion= parte uno + parte dos */
/*Cargamos la clase*/
/*la instanciamos */
/*la guardamos en el mapa de acciones*/

Programando Soluciones
LA PARTE JAVA

Action.java

Esta clase es un “molde” para las acciones esta clase se encarga de declaras 4 variables y
sus métodos sets y aparte un método abstracto run. Todas las Acciones heredan de esta
clase.

Para mas detalles ver el código en la aplicación.

Programando Soluciones
BASE DE
MODELO DATOS

VISTA CONTROLADOR

ACCIONES
ACCIONES
ACCIONES

Programando Soluciones
MODELO BASE DE
DATOS
-Model
-WebModel
-Beans
-Clases de la lógica de
negocio

VISTA CONTROLADOR
- Paginas para presentación -Controller
-Clases para presentación (re-direccionamiento de
(todo lo que interactué con el peticiones)
usuario).

ACCIONES
ACCIONES
ACCIONES

Programando Soluciones