JSP extendido

Page 1

Java Server Pages, Beans y JSP Tag Library Dr. Víctor J. Sosa Sosa vjsosa@cinvestav.mx Sintetizado del curso de Mark Baker University of Portsmouth, UK

1

Introducción

Introducción a los JSP. Elementos de JSP Scripting. JSP, directivas de página: Estructura y generación de Servlets. Incluyendo archivos en documentos JSP. Usar los componentes de JavaBeans con JSP. Creando JSP tag libraries personalizados. Integrando Servlets y JSP con la arquitectura MVC. 2


¿Porqué usar JSP?

Con Servlets es fácil:

Leer datos de un formulario, Leer las cabeceras de las peticiones HTTP. Leer los códigos de estado HTTP y las cabeceras de respuesta, Usar cookies y seguimiento de sesiones, Compartir Datos entre Servlets, Recordar datos entre peticiones.

Qué es lo difícil:

Usar muchas instrucciones println() para generar HTML, Mantenimiento del HTML.

3

El Framework de JSP

La idea:

Uso de HTML para la mayoría de las páginas Web, Identificar código del Servlet con etiquetas especiales, Toda la página JSP es convertida a un Servlet (sólo una vez) y el Servlet es el que realmente es invocado (por cada petición).

Ejemplo:

JSP:

URL:

Thanks for ordering <%=request.getParameter(“title”) %/> http://host/OrderConfirmation.jsp?title=Java+Servlets.

Result:

Thanks for ordering the “Java Servlets” 4


Java Server Pages (JSP)

Arquitectura de JSP

El propósito de JSP es ofrecer una forma más declarativa y más guiada por la presentación que aquella conseguida con los servlets. Las páginas JSP se utilizan en un proceso que involucra dos fases: 1. Una fase de traducción dinámica a servlets que se

2.

realiza únicamente cuando la página JSP se crea o modifica. Una fase de contestación a peticiones que se consigue cuando las clases de los servlets generados se cargan en el contenedor de servlets.

5

Java Server Pages (JSP)

Arquitectura de JSP

En la segunda fase, para atender concurrentemente al procesamiento de peticiones, el servidor lanza un proceso ligero (thread) por cada uno de los clientes el cual corre el método _jspService(). El método _jspService() no puede reemplazarse por otros métodos definidos por el programador, pero en cambio puede adecuarse su inicialización y terminación con los métodos jspInit() y jspDestroy().

6


Java Server Pages (JSP) Arquitectura de JSP

Evento de iniciación

Servlet

_jspInit() Petición Respuesta

Evento de terminación

_jspService()

_jspDestroy()

Contenedor de Servlets 7

Benéficos de usar JSP

Ventajas

Independencia del servidor Web. Substitución del API de los servlets por conjuntos de elementos de marcado (tags) y fragmentos de programación (scriptlets). Altamente recomendable para conseguir el acceso al servidor Web en arquitecturas de partes múltiples (multi-tier). Separación del contenido estático del dinámico. Separación del contenido dinámico del formato de la presentación. 8


Ventajas de JSP frente a las tecnologías similares.

Contra Active Server Pages (ASP):

ASP es una tecnología similar que pertenece a Microsoft La parte dinámica de JSP es escrita en Java, no en Visual Basic u otro lenguaje propietario de Microsoft, esto lo hace un mejor lenguaje. Es portable con otros sistemas operativos y servidores Web que no sean de Microsoft.

Contra Servlets:

JSP no proporciona algo más que en principio podría hacerse con un Servlet. Pero es mas conveniente para escribir y modificar HTML que tener muchas sentencias println() para generarlo. Además, haciendo la separación de vista y contenido, se puede tener diversas personas en diversas tareas: expertos en diseño de páginas Web pueden construir el HTML, dejando lugar para que los programadores de Servlets inserten el contenido dinámico.

9

Ventajas de JSP frente a las tecnologías similares.

Contra Server-Side Includes (SSI): SSI son tecnologías ampliamente soportadas para incluir, en una página Web estática, partes definidas externamente. JSP es mejor porque le permite utilizar Servlets en lugar de un programa separado para generar la parte dinámica, SSI está pensado para inclusiones simples, no para programas reales que usen información de un formulario, conexiones a bases de datos, etc. Contra JavaScript: JavaScript puede generar dinámicamente HTML del lado cliente, Capacidad útil, pero sólo para manejar situaciones donde la información dinámica está basada en el medio ambiente del cliente, Con excepción de las cookies de HTTP y los formularios, el envío de datos no es posible en JavaScript, Y, puesto que corre del lado cliente, JavaScript no puede tener acceso a los recursos del lado servidor como bases de datos, catálogos, información valiosa, entre otros. 10


Ventajas de JSP frente a las tecnologías similares.

Contra HTML estático:

El HTML normal, no puede contener información dinámica. JSP es tan fácil y conveniente que es totalmente factible aumentar las páginas HTML que se verán beneficiadas por la inserción de cantidades pequeñas de datos dinámicos.

11

Resumen: JSP vs ASP Propiedad

Java Server Pages

Active Server Pages

Servidor

La mayoría de los servidores más Conocidos (Apache, Netscape, MS IIS)

Los servidores de Microsoft (IIS y Personal Web Server)

Plataforma

Cualquiera que corra una máquina virtual Java

Windows

Modelo de componentes

Java Beans, Enterprise Java Beans y librerías de elementos

COM , DCOM , COM +

Programación (scripting)

Java

JavaScript o Visual Basic Script

Seguridad

Modelo de seguridad de Java

Modelo de seguridad de Windows NT

Bases de datos

Java Data Base Connectivity

Active Data Objects

Extensibilidad

Abierto a librerías de elementos

Ninguna 12


Malentendidos comunes: Recordar que JSP es tecnología Server-Side

Pregunta muy común:

¿Por qué esta pregunta no tiene sentido?

¿No puedo hacer XYZ con el HTML, JSP me dejaría hacerlo? JSP corre completamente del lado servidor, No cambia el contenido que el visualizador puede manejar.

Preguntas similares: ¿Cómo pongo un Applet en una página JSP? Respuesta: Envié una etiqueta del <APPLET…> al cliente. ¿Cómo pongo una imagen en una página JSP? Respuesta: Envié una etiqueta de la <IMG…> al cliente. ¿Cómo uso un JavaScript/Acrobat/Shockwave/etc? Respuesta: Envié las etiquetas correspondientes del HTML.

13

2do Malentendidos comunes: Tiempo de Traducción/Petición

¿Qué sucede al momento de traducción de la página JSP?

¿Qué pasa en el momento de la petición?

Las JSPs se traducen a código Servlet. El código del Servlet es ejecutado, Ninguna interpretación del JSP ocurre al momento de la petición, La página JSP original es ignorada al momento de la petición; solo el Servlet que resulte de la JSP es el que se toma en cuenta.

¿Cuándo ocurre la traducción de la página?

Generalmente la primera vez que la página JSP es invocada después de ser modificada, Esto no debería suceder a usuarios reales – los desarrolladores deben probar las páginas que instalan, La traducción de páginas no ocurre en cada petición. 14


http://www.delta.com/

15

https://portal.banamex.com.mx/esp/empresarial/monarca/login.jsp

16


http://www.excite.com/

17

Configurando el medio ambiente.

Configurar CLASSPATH. Compilar el c贸digo Utilizar los paquetes para evitar conflictos de nombres. Coloque la p谩gina JSP en el directorio correcto: <tomcat_home>/Webapps/ROOT.

Use el URL especial para invocar la p谩gina JSP. Advertencias:

Las reglas utilizadas para el acceso al CLASSPATH, instalaci贸n de directorios, etc., aun se aplican a las clases utilizadas en JSP.

18


Ejemplo.

19

Ejemplo

Con la configuraci贸n por defecto, si la localizaci贸n es:

<tomcat_home>/Webapps/ROOT/Expression.jsp

EL URL debe ser:

http://localhost:8080/Expressions.jsp

20


Ejemplo

21

Elementos del JSP Scripting

22


Uso de las JSPs

Los elementos de Scripting Aplicaciones simples llaman al código del Servlet directamente. Los elementos de Scripting llaman al código del Servlet indirectamente mediante clases de uso general(utilities). Uso de Beans. Etiquetas personalizadas. Servlet/JSP combo. Aplicaciones complejas

23

Tipos de elementos de Scripting

Expresiones:

Scriptlets:

Formato <%=expression %> Se evalua e inserta en la salida del Servlet, ej., el resultado en algo como: out.println(expression). Formato <%code%> Insertado textualmente dentro del método _jspService en los Servlet’s (llamada al servicio).

Declaraciones:

Formato <%! code%> Insertado textualmente dentro del cuerpo de la clase del Servlet, fuera de cualquier método existente.

24


Expresiones JSP

Formato:

Resultado:

Expresión evaluada, convertida a cadena, y puesta en la página HTML en el lugar donde ocurrió en la página JSP. Es decir, la expresión se pone en el _jspService dentro de out.print.

Ejemplos:

<%= Expresión Java %>

Tiempo actual: <%=new java.util.Date()%> Tu nombre de maquina: <% request.getRemoteHost()%>

Sintaxis compatible XML :

<jsp:expression> Java Expression </jsp:expression> Versión de XML no suportada por Tomcat 3.1 Hasta la versión JSP 1.2, los servidores no tiene que darle soporte. 25

Correspondencia JSP/Servlet

Original JSP: <H1> A Random Number </H1> <%= Math.random() %>

Resultado posible del código Servlet:

public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException IOException{ request.setContentType(“text/html”); HttpSession session = request.get Session(true); JspWriter out = response.getWriter(); out.println(“<H1> Random Number</H1>); out.println(Math.randon()); … } 26


Ejemplo usando expresiones JSP

27

Variables predefinidas

Request:

Response:

El HttpSession asociada a la petición (al menos que fuera deshabilitada con el atributo de la directiva de sesión).

Out:

El HttpSerlvetResponse – 2do argumento para doGet();

Session:

El HttpServletRequest – 1er argumento para doGet();

El flujo de datos (de tipo JspWriter) usado para enviar la salida al cliente.

Application:

El ServletContext (para compartir datos) como fue obtenido vía getServletConfig().getContext().

28


Java Server Pages (JSP)

Objetos Implícitos Objeto

Contexto

Descripción

Ámbito

request

HttpServletRequest

Invocación del servicio

Petición

response

HttpServletResponse

Respuesta a la Petición

Página

pageContext

jsp.PageContext

Características de la página Dependientes de la implementación, espacios de nombres y otras facilidades

Página

session

http.HttpSession

Conserva el estado de la session

Sesión

application

ServletContext

Contexto del servlet de configuración

Aplicación

out

jsp.JspWriter

Flujo de salida

Página

config

ServletConfig

Configuración del servlet del JSP

Página

page

Object

Página que procesa la petición en curso

Página

29

JSP Scriptlets

Formato:

Resultado:

El código insertado textualmente en el _jspService del Servlet.

Ejemplo:

<% Código Java %>

<%String queryData = request.getQueryString(); out.println(Attached GET data: “ + queryData);%> <%response.setContentType(text/plain”); %>

Sintaxis compatible XML:

<%jsp:scriptlet> Código Java </jsp:scriptlet>%> 30


Correspondencia JSP/Servlet

Original JSP: <%= foo() %> <%= bar() %>

Posible resultado del código Servlet: public void _jspService(HttpServletRequest request, HttpServletResponse response) throws ServletException IOException{ request.setContentType(“text/html”); HttpSession session = request.get Session(true); JspWriter out = response.getWriter(); out.println(foo()); out.println(bar()); … }

31

Ejemplo usando JSP Scriptlets

32


Ejemplo usando JSP Scriptlets

33

Declaraciones JSP

Formato:

Resultado:

El código se inserta textualmente en la definición de la clase del Servlet, fuera de cualquier método existente.

Ejemplos:

<%! Código Java %>

<%! private int algunCampo=5;%> <%! private void AlgunMetodo(…) {…} %>

Sintaxis compatible XML :

<jsp:declaration> Código Java </jsp:declaration> 34


Declaraciones JSP

JSP: <H!>Someheading</H1> <%! private String randomHeading(){ return(“<H2>” + Math.random() + “</H2>”); } %> <%= randomHeading()%>

35

Ejemplo usando declaraciones JSP <!DOCTYPE HTML PUBLIC "//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>JSP Declaraciones</TITLE> </HEAD> <BODY> <H1>JSP Declaraciones</H1> <%! private int accessCount = 0; %> <H2>Accesses to page since server reboot: <%= ++accessCount %></H2> </BODY> </HTML>

36


Java Server Pages (JSP) Ejemplo de una Página JSP: La siguiente página JSP presenta un saludo. <%-- Esta página da un saludo y despedida --%> <HTML> <BODY> <H1>Bienvenido a JSP!</H1> <% out.println("Regrese pronto”); %> </BODY> </HTML> N bienvenido

helloworld

hellouser

response

NameHandler 37

Java Server Pages (JSP) Ámbito y Visibilidad de los Objetos JSP Los objetos JSP pueden crearse:

implícitamente por directivas JSP explícitamente a través de acciones excepcionalmente usando fragmentos de código

El ámbito del objeto establece su duración desde su creación hasta su destrucción; su visibilidad indica los lugares de la página donde puede usarse el objeto.

38


Java Server Pages (JSP) Ámbito y Visibilidad de Objetos

La siguiente tabla muestra los ámbitos que pueden asociarse a los objetos recién creados.

Ámbito

Categoría

Descripción

4 (mayor)

Aplicación

Pertenecen a la misma aplicación

3

Sesión

Pertenecen a la misma sesión

2

Petición

Provienen de la petición que es Atendida

1 (menor)

Página

Pertenecen a la página en que fueron creados 39

Java Server Pages (JSP) Objetos Implícitos Debido a que la tecnología JSP se basa en aquella de los servlets, existe un conjunto de objetos predefinidos cuyos nombres pueden usarse inmediatamente en JSP.

40


Java Server Pages (JSP) Ejemplo Este ejemplo muestra los cuatro ámbitos de los objetos JSP. <%@page import=“java.util.*”%> <HTML> <BODY> Servlet <%= config.getServletName() %><br> <% for (int scope = 1; scope <= 4; scope++) { out.println("<H2>Ambito "+scope+"</H2>"); Enumeration e = pageContext.getAttributeNamesInScope(scope); while (e.hasMoreElements()) { out.println(e.nextElement()+”<br>”); } } %> </BODY> </HTML> 41

ambitos

Java Server Pages (JSP) Resumen de Elementos Básicos de JSP

Elementos que se intercalan entre aquellos de HTML o XML.

Elemento

Sintaxis

Descripción

Directiva

<%@ . . . . . . . . %>

Importar clases o incluir archivos HTML

Declaraciones

<%! . . . . . . . . . . %>

Declarar variables o métodos Java

Expresiones

<%= . . . . . . . . .. %>

Evaluación de expresiones Java

Scriptlets

<% .. . . . . . . . . .. %>

Ejecución de instrucciones Java

Comentarios

<%-- .. . . . .. . . -- %>

Texto no procesado 42


JSP: Resumen Elementos Básicos Directivas Las directivas son instrucciones dirigidas al contenedor de servlets JSP, no al flujo de salida. Las directivas determinan los atributos de la página y las dependencias con el contenedor. La directiva de página tiene la forma: <%@ page atributos %> donde los atributos pueden ser:

language que indica el lenguaje usado en la página JSP, import que establece las clases que se van usar extends que indica las clases que serán extendidas include que inserta un archivo HTML session que cuando toma el valor true, permite usar la variable predefinida session en la página JSP buffer que establece el tamaño del área temporal de la página autoflush que indica si el envío al flujo de salida es inmediato isThreadSafe que establece que a lo más un proceso está activo a la vez (por omisión, se tienen múltiples procesos concurrentes) errorPage que permite indicar si la página se usa para anunciar un error 43

JSP: Resumen Elementos Básicos Ejemplos de Directivas Las directivas:

<%@ page import=”java.sql.*,java.util.*” %> importa los paquetes java.sql y java.util <%@ page include=”sty.css” %> inserta los estilos para el documento que están guardados en el archivo sty.css <%@ page buffer=”16k” %> establece el tamaño del buffer a 16k <%@ page isThreadSafe=”true” %> establece que hay sólo un proceso activo a la vez

44


JSP: Resumen Elementos Básicos Declaraciones La sintaxis de una declaración es <%! declaración %> o, alternativamente, usando los espacios de nombres de XML <jsp:declaration> declaración </jsp:declaration>

Las declaraciones permiten introducir variables y métodos a nivel de página y deben seguir la sintaxis de Java. Las variables declaradas pueden inicializarse y deben estar terminadas por punto y coma. Las declaraciones de métodos, además de aquellos usados en la aplicación, pueden también incluir a jspInit() y jspDestroy(). 45

JSP: Resumen Elementos Básicos Ejemplo de Declaración Código de iniciación para un contador en una página JSP que declara una variable y los métodos jspInit() y jspDestroy(): <%! int counter;%> <%! public void jspInit() { counter = 0; } public void jspDestroy() { } %>

46


JSP: Resumen Elementos Básicos Expresiones

La sintaxis de una expresión es <%= expresión %> o, alternativamente, usando los espacios de nombres de XML <jsp:expression> expresión </jsp:expression> Las expresiones en JSP permiten que el resultado de la evaluación de una expresión Java se convierta a una cadena de caracteres que será incluida en la página generada. Las expresiones pueden incluirse en gran variedad de contextos y no deben terminarse por puntos y comas. Ejemplo de Expresiones

La siguiente expresión produce un elemento H1 usado para escribir el texto de un encabezado: <%! int i = 1; %> <H<%=i%>>Java Server Pages</H<%=i>>

47

JSP: Resumen Elementos Básicos Scriptlets La sintaxis de un scriptlet es <% scriptlet %> o, alternativamente, usando los espacios de nombres de XML <jsp:scriptlet> scriptlet </jsp:scriptlet> Se puede escribir cualquier fragmento de código Java, extendido por elementos HTML y no limitado a una línea. Ejemplo de Scriptlets: El siguiente scriptlet produce una secuencia de encabezados con tamaño decreciente: <% for (int i=1; i<5; i++) { %> <H<%=i%>>Java Server Pages</H<%=i>> <% } %>

48


JSP: Resumen Elementos Básicos Comentarios comentarios JSP usan elementos especiales, Los distintos de los comentarios de HTML, para que no puedan verse en los documentos enviados al cliente. Los comentarios pueden usarse también para bloquear la ejecución de ciertos fragmentos de la página JSP. Ejemplo: La siguiente instrucción no será ejecutada (ni siquiera será visible en la página enviada al cliente) <%-- int i = 1; --%>

49

JSP: Ejemplo (contador de accesos) Ejemplo de Contador de Accesos: La siguiente página JSP muestra un contador de accesos a una página. <%-- Esta página da la fecha y hora cuando fue soliciatada así como el número de accesos --%> <%@ page import="java.util.*"%> <%! Date loadDate = new Date(); int loadCounter = 1; %> <HTML> <BODY> <H1>Bienvenido!</H1> <H2>Desde <%=loadDate%>, ésta página ha sido accesada <%=loadCounter%> <% if (loadCounter++ == 1) out.println("vez.<BR>"); else out.println("veces.<BR>"); %> <% out.println("Regrese pronto"); %> </H2> </BODY> </HTML> 50

contadoryfecha


JSP: Ejemplo (uso de formularios) Ejemplo con Formas: El siguiente ejemplo demuestra como obtener los valores de un formulario. <%@page import="java.util.*"%> <HTML> <BODY> <%Enumeration fields = request.getParameterNames();%> <TABLE border="1" > <TR><TH>Nombre</TH><TH>Valor</TH></TR> <% while (fields.hasMoreElements()) { %> <TR> <%String field = (String)fields.nextElement();%> <TD align=center><%=field%></TD> <TD align=center> <%=request.getParameter(field)%></TD> </TR> <%}%> </TABLE> </BODY> </HTML> 51

formulario

programa

JSP: Manejo de Concurrencia Concurrencia

La directiva page con el atributo isThreadSafe ofrece una forma de evitar los problemas que ocasiona la concurrencia. El problema con este enfoque es que no es escalable, reduciendo considerablemente el desempeño de sistemas con muchos procesos. Una alternativa es usar regiones críticas en scriptlets para sincronizar el acceso a objetos compartidos. <%@page import=”java.util.*”%> <% synchronized (application) { Properties list = application.getAttribute(“users”); list.add(“ana”,new User(“ana”)) list.setAttribute(“users”,list); } %> 52


JSP: Manejo de Excepciones Manejo de Excepciones JSP posee un mecanismo apropiado para el manejo de errores que ocurren a tiempo de ejecución. El atributo errorPage de la directiva page se usa para indicar que la página recibe las excepciones lanzadas por algún scriptlet. Además, el atributo errorPage de la misma directiva indica la página JSP a la cual se redirigirá el objeto implícito exception (de tipo Throwable) que describe el problema.

53

JSP: Manejo de Excepciones… Ejemplo de manejo de excepciones Para manejar errores a tiempo de ejecución, se puede usar una página que indique la naturaleza del error. Dicha página debe incluir entre sus directivas la siguiente:

<%@page isErrorPage=”false” errorPage=”Error.jsp”%> la página redirige a su vez el objeto exception a la página Error.jsp . La página Error.jsp debe contener a su vez, la

directiva:

<%@page isErrorPage=”true” %>

Esta indicación permite acceder al objeto exception en la página Error.jsp . 54


JSP: Manejo de Sesiones Manejo de Sesiones Por omisión todas las páginas JSP participan en una sesión HTTP. El objeto session (de tipo HttpSession) está disponible para almacenar objetos que persistan a lo largo de la vida de la aplicación. El atributo session de la directiva page se usa para permitir o negar el acceso al objeto session en la página; por omisión, el objeto session es accesible. La directiva <%page session=”false”%> indica que en la página no se usarán sesiones. Una sesión se identifica por un nombre único de sesión y se almacena en el browser del cliente en forma de cookie; si el browser no maneja cookies, la sesión se mantiene por reescritura del URL. La sesión mantiene referencias a todos los objetos almacenados pero tan pronto como la sesión es invalidada o el plazo de los objetos expira, los objetos se marcan para su recolección como basura. 55

JSP: Manejo de Sesiones…. Manejo de Sesiones No se pueden guardar tipos simples en una sesión, pero se puede guardar cualquier tipo de objeto identificado por una cadena única de caracteres. El siguiente scriptlet hace al objeto Book públicamente disponible para todas las páginas y servlets JSP que compartan la misma sesión: <% Book book = new Book(); session.putValue(“book”,book); %> El objeto book puede recuperarse realizando una coerción para convertirlo al tipo apropiado: <% Book book = (Book)session.getValue(“book”); %> No hay límite en el número de objetos que se pueden manejar en una sesión, aunque un gran número de ellos reducirá el rendimiento del sistema. Generalmente, la duración de una sesión está limitada a 30 minutos, aunque la duración puede ampliarse regularmente usando el método setMaxIntactiveInterval(int secs). 56


JSP: Ejemplo de Sesiones <%--session.jsp: Ejemplo de una sesion--%> <HTML> <BODY> <H1>Sesion <%=session.getId()%></H1> <P>La session fue creada el <%=session.getCreationTime()%> <P>Duracion usual de la session:<%=session.getMaxInactiveInterval()%> <P>Reducción de la duracion de la session a 5 segundos <%session.setMaxInactiveInterval(5);%> <P>Nueva duracion de la session:<%=session.getMaxInactiveInterval()%> <P>Depositar un objeto nuevo <%session.setAttribute("bible",new String("Sacred Bible"));%> <P>Mostrar el objeto depositado:<%=session.getAttribute("bible")%> </BODY> <HTML>

session 57

JSP: Ejemplo de Sesiones <%--session1.jsp: Ejemplo de una sesion con invalidacion--%> <HTML> <BODY> Sesion <%= session.getId() %> <% if (session.getAttribute("bible")==null) { session.setAttribute("bible",new String("Sacred Bible")); out.println("<P>Depositar un nuevo libro:" +session.getAttribute("bible")); } else { out.println("<P>Recuperar el libro:" +session.getAttribute("bible")); } %> <FORM TYPE="post" ACTION="session2.jsp"> <INPUT TYPE="submit" NAME="invalidar“ VALUE="invalidar"> </FORM> <FORM TYPE="post" ACTION="session3.jsp"> <INPUT TYPE="submit" NAME="conservar“ VALUE="conservar"> </FORM> </BODY> session1 </HTML> 58


JSP: Ejemplo de Sesiones (Cont..)

Los archivos session2.jsp y session3.jsp son llamados por session1.jsp. <%--session2.jsp: Ejemplo de una sesion con invalidacion--%> <%@page isErrorPage="false“ errorPage="ErrorPage.jsp"%> <HTML> <BODY> Sesion <%=session.getId()%> <P>Recuperar al libro: <%= session.getValue("bible") %> <P>Invalidar la session <% session.invalidate(); %> <P>Recuperar de nuevo al libro: <%= session.getValue("bible") %> <FORM TYPE="post" ACTION="session1.jsp"> <INPUT TYPE="submit" NAME="submit“ VALUE="regresar"> </FORM> </BODY> </HTML> <%--session3.jsp--%> <HTML> <BODY> Sesion <%=session.getId()%> <P>Recuperar el libro: <%= session.getValue("bible") %> <FORM TYPE=”post” ACTION=”session1.jsp”> <INPUT TYPE=”submit” NAME=”submit” VALUE=”regresar”> </FORM> </BODY> session2 session3 </HTML>

ErrorPage

59

JSP: Uso de Cookies Uso de cookies cookies ya fueron introducidas en la Las programación con servlets; en JSP es igual de simple su programación. Las cookie se obtienen de la petición HTTP (objeto request) y se mandan a la respuesta HTTP (objeto response) siempre que el cliente acepte las cookies. Una vez obtenida una cookie de la petición, ésta se puede leer, modificar y alterar su fecha de expiración (cambiando su edad máxima). Además, en cualquier momento se puede agregar nuevas cookies a las ya existentes.

60


JSP: Ejemplo de Cookies <%--Cookies.jsp: Este programa puede comportarse distinto en diferentes browsers--%> <HTML> <BODY> Session <%= session.getId() %> <% Cookie[] cookies = request.getCookies(); for(int i = 0; i < cookies.length; i++) { %> Cookie con nombre: <%= cookies[i].getName() %> <br> Valor: <%= cookies[i].getValue() %><br> Duración máxima en segundos: <%= cookies[i].getMaxAge() %><br> <% cookies[i].setMaxAge(5); %> Nueva duración en segundos: <%= cookies[i].getMaxAge() %><br> <% } %> <%! int count = 0; int dcount = 0; %> <% response.addCookie(new Cookie("Bob" + count++,"Dog" + dcount++)); %> </BODY> </HTML>

Cookies

61

JSP: Acciones comunes Acciones Comunes Las acciones permiten realizar tareas sofisticadas reduciendo considerablemente la codificación requerida en Java. Las acciones se manifiestan usando elementos especiales (tags) los cuales promueven la reutilización de componentes mejorando el mantenimiento de la aplicación. Algunas acciones más populares son:

usar componentes JavaBeans redirigir mensajes encadenar peticiones incluir peticiones

62


JSP: Usar componentes JavaBeans

El modelo de componentes de JSP se basa en la tecnología JavaBeans que son objetos con un esquema de nombramiento bien definido. Un bean encapsula sus propiedades, como variables privadas, las cuales se pueden leer o modificar usando métodos públicos apropiados. Un bean debe identificarse con un nombre con ámbito de sesión antes de que pueda usarse; el elemento XML <jsp:useBean

id=”bookBean”

class=”com.beans.books”

scope=”session”/>

crea una instancia del Bean y lo agrega a la sesión; si se encuentra este elemento en otra página, el objeto se recuperará entonces de la sesión. 63

JSP: Usar componentes JavaBeans

El elemento jsp:useBean también puede tener estructura, la cual consiste de un scriptlet que realiza la iniciación de las propiedades del bean cuando éste se crea. <jsp:useBean id=”bookBean” class=”com.beans.books” scope=”session”> <% iniciación de propiedades del bean %> </jsp:useBean>

Una vez declarados los beans, sus propiedades pueden accederse usando el elemento <jsp:getProperty name=”book” property=”name”/>

Para cambiar el valor de una propiedad, se usa el elemento <jsp:setProperty name=”book” property=”name” value=”Thinking in Java”/>

En el procesamiento de formas es muy conveniente usar las facilidades que brinda JSP para copiar los valores asociados de los campos a los atributos del bean. 64


JSP: Usar componentes JavaBeans

El elemento <jsp:setProperty name=”book” property=”*”/>

copia los valores pero sólo cuando los nombres en ambos (los campos de la forma y los atributos del bean) coinciden. Cuando los nombres no coinciden, la correspondencia se debe hacer explícita:

<jsp:setProperty name=”book” property=”propName” parameter=”parmName”/>

65

JSP: Ejemplo de JavaBeans

El siguiente JSP es un juego para adivinar un número.

Copyright (c) 1999 The Apache Software Foundation. All rights reserved. Number Guess Game Written by Jason Hunter, CTO, K&A Software http://www.servlets.com --> <%@ page import = "num.NumberGuessBean" %> <jsp:useBean id="numguess“ class="num.NumberGuessBean" scope="session"/> <jsp:setProperty name="numguess" property="*"/> <html> <head><title>Number Guess</title></head> <body bgcolor="white"> <font size=4> <% if (numguess.getSuccess()) { %> Congratulations! You got it. And after just <%= numguess.getNumGuesses() %> tries.<p> <% numguess.reset(); %> Care to <a href="numguess.jsp">try again</a>? <% } else if (numguess.getNumGuesses() == 0) { %> Welcome to the Number Guess game.<p>

numguess

66


JSP: Ejemplo de JavaBeans (Cont…)

I'm thinking of a number between 1 and 100.<p> <form method=get> What's your guess? <input type=text name=guess> <input type=submit value="Submit"> </form> <% } else { %> Good guess, but nope. Try <b> <%= numguess.getHint() %></b>. You have made <%= numguess.getNumGuesses() %> guesses.<p> I'm thinking of a number between 1 and 100.<p> <form method=get> What's your guess? <input type=text name=guess> <input type=submit value="Submit"> </form> <% } %> </font> </body> </html>

67

JSP: Ejemplo de JavaBeans (Cont…)

El siguiente JavaBean se usa en el juego de adivinanza de números. /* Originally written by Jason Hunter */ package num; import java.util.*; public class NumberGuessBean { int answer; boolean success; String hint; int numGuesses; public NumberGuessBean() { reset(); } public void setGuess(String guess) { numGuesses++; int g; try { g = Integer.parseInt(guess); } catch (NumberFormatException e) { g = -1; } if (g == answer) { success = true; } else if (g == -1) {hint = "a number next time";

NumberGuessBean

68


JSP: Ejemplo de JavaBeans (Cont…) } else if (g < answer) { hint = "higher";} else if (g > answer) { hint = "lower"; } } public boolean getSuccess() { return success; } public String getHint() { return "" + hint; } public int getNumGuesses() { return numGuesses; } public void reset() { answer = Math.abs(new Random().nextInt() % 100) + 1; success = false; numGuesses = 0; } } 69

JSP: Redirigir mensajes

Una petición se puede redirigir hacia otra página JSP, servlet o página HTML estática pasándole el contexto de la página que hace la invocación. El procesamiento continúa hasta el punto en el que ocurre la redirección para entonces detenerse por completo en esa página. El elemento <jsp:forward page=”anotherPage.jsp”/> redirige el procesamiento a la página anotherPage.jsp conservando todo el procesamiento realizado en la página actual. Un elemento <jsp:forward> también puede tener parámetros para proporcionar valores a la página invocada: <jsp:forward page=”anotherPage.jsp”> <jsp:param name=”aName1” value=”aValue1”/> <jsp:param name=”aName2” value=”aValue2”/> </jsp:forward> 70


JSP: Ejemplo, redirigir mensajes <html> <!-- Copyright (c) 1999 The Apache Software Foundation. All rights reserved. --> <% double freeMem = Runtime.getRuntime().freeMemory(); double totlMem = Runtime.getRuntime().totalMemory(); double percent = freeMem/totlMem; if (percent < 0.5) { %> <jsp:forward page="/jsp/forward/one.jsp"/> <% } else { %> <jsp:forward page="two.html"/> <% } %> </html>

71

JSP: Ejemplo, redirigir mensajes (Cont‌.) <!--one.jsp--> <html> <!-- Copyright (c) 1999 The Apache Software Foundation. All rights reserved. --> <body bgcolor="white"> <font color="red"> VM Memory usage < 50%. </html> <!--two.jsp--> <html> <!-- Copyright (c) 1999 The Apache Software Foundation. All rights reserved. --> <body bgcolor="white"> <font color="red"> VM Memory usage > 50%. </html>

72


JSP: Incluir páginas

El elemento <jsp:include> puede usarse para redirigir una petición a cualquier página estática o dinámica que esté en el mismo contexto. La llamada también puede incluir los beans como parámetros de la petición. Por ejemplo, el elemento <jsp:include page=”shopingCart.jsp” flush=”true”/> permite tener acceso a cualquier bean y al contexto dinámico generado por la página invocante; finalmente, el contenido generado se inserta en el lugar del elemento <jsp:include>. La página incluida no puede hacer algunas cosas como encabezados HTTP o hacer galletas. 73

JSP: Ejemplo de incluir páginas La siguiente página inserta la fecha producida por otra. <html> <!-- Copyright (c) 1999 The Apache Software Foundation. All rights reserved. --> <body bgcolor="white"> <font color="red"> <%@ page buffer="5k" autoFlush="false" %> <p>In place evaluation of another JSP which gives you the current time: <%@ include file="foo.jsp" %> <p> <jsp:include page="/jsp/include/foo.html“ flush="true"/> by including the output of another JSP: <jsp:include page="foo.jsp" flush="true"/> :-) </html> El JSP que produce la hora: <!-- Copyright (c) 1999 The Apache Software Foundation. All rights reserved. --> <body bgcolor="white"> <font color="red"> <%= System.currentTimeMillis() %> 74


Repaso a la directiva page de JSP : Usada como forma para estructurar los Servlets generados

75

Propósito de la directiva page

Dar información de alto nivel a cerca del Servlet que resulte del JSP. Puede controlar:

Qué clases son importadas, Qué clases el Servlet extiende o hereda, Qué tipo MIME se genera, Cómo se maneja el multi-threading. Si el Servlet participa en sesiones, El tamaño y compartimiento del buffer de salida, Qué página maneja los errores inesperados. 76


El atributo Import

Formato:

Propósito:

<%@ page import=“package.class” %> <%@ page import=“paqckage1,…, package.classN”%> Generar las declaraciones para importar clases en la parte superior del Servlet.

Notas:

Aunque las páginas JSP pueden estar casi en cualquier parte del servidor, las clases usadas por JSP deben estar en directorios comunes del Servlet. Por ejemplo, con Tomcat esto es: $CATALINA_HOME/Webapps/ROOT/Web-INF/classes

77

Ejemplo del atributo import

mab.*

78


Ejemplo del atributo import Primer Acceso

Acceso Posterior

79

El atributo contentType

Formato: <%@ page contentType=“MIME-Type”%> <%@ page contentType=“MIME-Type; charset=Character-Set”%>

Proposito:

Especifica el tipo MIME de la página generada por el Servlet que resulta de la página JSP .

80


El atributo contentType First Last Email Address Mark Baker mark.baker@computer.org Larry Brown brown@coreWebprogramming.com Bill Gates gates@sun.com Larry Ellison ellison@microsoft.com <%@ page contentType="application/vnd.ms-excel" %> <%-- Son tabs en lugar de espacios entre las columnas --%>

81

El atributo isThreadSafe

Formato:

Propósito:

<%@ page isThreadSafe=“true”%> <%-- Default--%> <%@ page isThreadSafe=“false”%> Le dice al sistema cuando el código no es threadsafe, de modo que el sistema pueda prevenir accesos concurrentes – instruye al Servlet a implementar un SingleThreadModel.

Notas:

Por defecto es true – El sistema asume que se tienen actualizaciones a campos y otros datos compartidos sincronizadamente. Proporcionando el valor false se puede afectar el buen desempeño.

82


Código Non-threadsafe

¿Cuál es el problema con este código? <%! private int idNum = 0;%> <% String UserID = “userID” + idNum; out.println(“Your ID is “ + userID + “.”); idNum = idNum + 1; %>

83

Código Threadsafe <%! private int idNum = 0;%> <% synchronized(this) { String UserID = “userID” + idNum; out.println(“Your ID is “ + userID + “.”); idNum = idNum + 1; } %>

acceso seguro a una variable compartida usando la declaración de sincronización normal. 84


Otros atributos de la directiva de page

Session:

Buffer:

Cambia la clase padre del Servlet generado.

Error:

Requiere al desarrollador explícitamente vaciar el buffer.

Extends:

Cambia el tamaño minimo del buffer usado por el JspWriter.

Autoflush:

Permite Elegir no participar en sesiones.

Indica una página para manejar los errores inesperados.

isErrorPage:

Indica que la página se puede utilizar como página del error. 85

Incluyendo archivos en documentos JSP

86


Incluyendo páginas al momento de la petición

Formato: <%jsp:include page=“URL relativo” flush=“true”%>

Propósito:

Reutilizar contenido JSP, HTML o texto plano. El contenido JSP no puede afectar la página principal – Solamente es utilizada la salida de JSP incluido. Permitir actualizaciones al contenido incluido sin cambiar la página principal.

87

Ejemplo de inclusión de páginas

88


Ejemplo de inclusión de páginas

89

Incluyendo archivos al momento de la traducción de la página.

Formato: <%@include file=“Relative URL”%>

Propósito:

Reutilizar contenido JSP en múltiples páginas, donde el contenido JSP afecta la página principal.

Notas:

Los servidores no tiene que detectar cambios en los archivos incluidos, y en la práctica muchos no lo hacen – de otra manera se necesita cambiar los archivos JSP cuando los archivos incluidos cambian. Puede utilizar mecanismos específicos del sistema operativo tal como el comando touch de UNIX:

<%-- Navbar.jsp modified 27/01/03--%> <%@include file=“Navbar.jsp%> 90


Contenido JSP reutilizable: Ejemplo: ContactSection.jsp <%@ page import="Java.util.Date" %> <%-- Los siguientes viene a ser campos en cada Servlet que resulta de una página JSP que incluye este archivo. --%> <%! private int accessCount = 0; private Date accessDate = new Date(); private String accessHost = "<I>No previous access</I>"; %> <P> <HR> This page © 2000 <A HREF="http//www.my-company.com/">my-company.com</A>. This page has been accessed <%= ++accessCount %> times since server reboot. It was last accessed from <%= accessHost %> at <%= accessDate %>. <% accessHost = request.getRemoteHost(); %> <% accessDate = new Date(); %> 91

Usando el ContactSection

Embebido en la página Web: <HTML> <BODY> <HR> <H1> My Page</H!> <HR> <%@ include file=“contactSection.jsp” %> </BODY> </HTML> 92


Creando bibliotecas de etiquetas JSP personalizadas Los bibliotecas de etiquetas JSP (JSP TL) permiten definir y utilizar etiquetas JSP similares a como se definen y usan en funciones típicas en los lenguajes de programación.

93

Bibliotecas de etiquetas JSP

La introducción de los Servlets en 1996 hizo a Java una opción razonable para el desarrollo de páginas Web dinámicas. El debut de JavaServer Pages (JSP) seguido por la inclusión del soporte para etiquetas JSP, fueron pasos lógicos en la evolución hacia una rápida y mantenible implementación de páginas Web en Java. Pero la liberación de JSTL (JSP Standard Tag Library) hecha a mediados del 2002 representa tal vez el paso más grande en cuanto a velocidad y simplificación del proceso de desarrollo. JSP 2.0 fue liberado en el 2004 y trajo nuevas mejoras y ayudas adicionales, Tomcat 5.5 comenzó a darle soporte a esta versión en el 2004. 94


La biblioteca de etiquetas JSP

Las páginas JSTL son también páginas JSP:

También, todas las etiquetas JSTL es XML válido:

Eso significa que si trata el contexto de una página fuera de las etiquetas JSTL como una plantilla de texto (el cual normalmente será HTML), las etiquetas JSTL restantes deben ser tratadas como XML válido.

JSTL proporciona un conjunto de cuatro bibliotecas estándares (core, internationalization/format, XML y SQL) y soporte para un lenguaje de expresiones (EL: Expression Language).

JSTL es justamente un súper conjunto de la funcionalidad del JSP.

Un objetivo primario del diseño para JSTL y de EL fue simplificar el desarrollo e implementación de las páginas Web.

Una etiqueta JSTL corresponde a alguna acción; llamándolas acciones, nos recuerdan explícitamente que están agregando comportamiento dinámico a una página que de otra manera sería estática. Puede usarse tanto expresiones JSP como JSTL EL.

95

¿Cómo obtener la Librería de Etiquetas?

El proyecto Apache Taglibs es un repositorio opensource para las bibliotecas de etiquetas personalizadas JSP y proyectos asociados, tales como las clases TagLibraryValidator y extensiones a herramientas para creación de páginas que soportan biblioteca de etiquetas. Jakarta Taglibs http://jakarta.apache.org/taglibs/ Para utilizar el estándar Taglib de la distribución Jakarta Taglibs, simplemente copie los archivos JAR que están en el directorio lib de la distribución al directorio de la aplicación Web-INF/lib.

JSTL 1.0 API classes: jstl.jar, Standard Taglib JSTL implementation classes: standard.jar.

96


Instalando JSTL

Para utilizar el JSTL, se debe tener un contenedor JSP 1.2 (o superior) instalado.

Uno de los contenedores JSP mas comรบnmente utilizados es el servidor Web Apache Tomcat .

Usando sรณlo Tomcat podrรก usar cรณdigo JSP normal. Para utilizar JSTL, se deberรก instalar JSTL en Tomcat. JSTL se puede obtener del mismo lugar que el Tomcat.

El URL principal para el JSTL es http://Java.sun.com/products/jsp/jstl/ Para usar JSTL, se deberรก descomprimir los archivos de la distribuciรณn e instalarlos en el lugar correcto dentro de Tomcat. 97

Instalando el JSTL

Copie el archivo JAR del JSTL al directorio lib de Tomcat:

Copie los archivos JSTL TLD al directorio WEB-INF de Tomcat:

Si usas Windows la localizaciรณn del directorio lib normalmente es $CATALINA_HOME\Webapps\ROOT\WEB-INF\lib.

El directorio Web-INF normalmente es: $CATALINA_HOME\ROOT\WEB-INF\tags\. Si tu examinas los archivos de la distribuciรณn JSTL, notarรกs que hay ocho con la extensiรณn TLD que deberรกn ser copiados al directorio WEB-INF.

Modificar el archivo Web.xml para incluir los archivos .tld:

Finalmente se deberรก modificar el archivo Web.xml y agregar una entrada para los archivos tag libraries que usted agregue. Esto consiste en agregar directivas <taglib> dentro de la directiva principal <Web-app>.

98


Instalando JSTL – Web.xml

99

Instalando JSTL

Después de completar los tres pasos anteriores, esta listo para probar la instalación del JSTL. Esto puede ser hecho creando una página JSP que utilice JSTL. Se debe de colocar el archivo JSP dentro del directorio raíz del Web. ($CATALINA_HOME\Webapps\ROOT). Una vez que el servidor Tomcat es iniciado, se debe ahora poder visualizar http://localhost:8080/XXXX.jsp para ver su página.

100


Instalando JSTL

Si no se tiene instalado correctamente el JSTL, normalmente no habrá mensaje de error. Si JSTL no esta interpretando sus etiquetas, éstas serán pasadas directamente al visualizador Web. El Visualizador Web interpretara estas etiquetas como etiquetas desconocidas del HTML. La mayoría de los visualizadores Web normalmente ignoran estas etiquetas desconocidas.

101

Bibliotecas de etiquetas JSTL

Se habla comúnmente de JSTL como una biblioteca de etiquetas simple. JSTL son en realidad cuatro bibliotecas de etiquetas. Estos bibliotecas son:

Core Tag Library – etiquetas que son esenciales para cualquier aplicación Web. Ejemplos de esta biblioteca de etiquetas incluyen ciclos, evaluacion de expresiones, entradas y salidas basicas. Formatting/Internationalization Tag Library – etiquetas que se utilizan para analizar datos. Algunas de estas etiquetas analizarán datos, tales como fechas basadas en forma diferente dependiendo de la localizacion. Database Tag Library – etiquetas que pueden ser utilizar para tener acceso a las bases de datos con SQL. XML Tag Library – etiquetas que se pueden utilizar para tener acceso a elementos XML. Debido a que XML es utilizado en muchas aplicaciones Web, el procesamiento de XML es una característica importante de JSTL. 102


Lenguaje de expresiones (EL)

(EL) define un lenguaje para expresar expresiones simples en una sintaxis que sea fácil de aprender. (EL) fue inspirado en JavaScript y en cierto grado en XPath, pero EL es mucho más flexible con variables sin valor (null) y realiza más conversiones de tipos en forma automática. Estas características son importantes para aplicaciones en el Web, donde la entrada esta principalmente en forma de parámetros de petición:

Los cuales pueden estar presentes en algunas peticiones pero en otras no, y el visualizador siempre envía los parámetros de petición como valores de texto, mientras que la aplicación a menudo necesita usarlos como números o valores booleanos (falso o verdadero). De la manera como EL está diseñado, rara vez necesitamos preocuparnos por ausencia de valores o conversión de tipos. 103

Lenguaje de expresiones (EL)

Una expresión EL contiene variables y operadores. Cualquier Bean contenido en uno de los ámbitos del JSP (página, petición, sesión o aplicación) puede ser utilizada como una variable EL. Las expreesiones del EL combinadas con etiquetas JSTL tomadas de las cuatro bibliotecas estándares, provee un conjunto amplio y flexible de características. Todas las expresiones EL están encerradas en ${ }. Las expresiones en JSTL son siempre parte de valores de atributos en las etiquetas JSTL:

Las expresiones pudieran ser la única parte del atributo o pudieran estar combinadas e incrustadas en literales de cadena. Los atributos de JSTL pueden también contener simples literales de cadenas. 104


Lenguaje de expresiones (EL)

Aquí tenemos a EL que agrega 5 a una variable llamada amount: ${amount + 5}

Si se desea agregar 5 al valor de una propiedad de un Bean, se utiliza el operador que accede a la propiedad: ${order.amount + 5}

EL operador de acceso (punto) le dice a EL que busque por la propiedad indicada (amount, en este caso) en el Bean o colección especifica (order, en este caso, el cual puede ser un Bean o Java.util.Map). 105

Lenguaje de expresiones (EL)

Como alternativa, se puede usar el operador de acceso a elementos de un arreglo: ${order['amount'] + 5}

El valor entre los corchetes debe ser tanto una cadena para el nombre de la propiedad (como en este ejemplo) o una variable (o aun una sub-expresión EL completa ) que mantiene el nombre de la propiedad. Las expresiones EL pueden ser utilizadas para asignar valores a cualquier atributo de acción estándar o personalizado de JSP que acepte un valor dinámico (o valores de atributo request-time, como se llaman formalmente): <c:out value="${order.amount + 5}"/> 106


Lenguaje de expresiones (EL)

EL proporciona soporte para acceder propiedades de objetos y elementos de colecciones, un conjunto de objetos impl铆citos y utilizar operadores relacionales l贸gicos y aritm茅ticos. Para las propiedades indizadas, incluyendo arreglos y clases Java.util.List, los elementos pueden ser accedidos con la sintaxis siguiente: ${alist[4]} ${aList[someVariable]}

107

Lenguaje de expresiones (EL)

Las propiedades de JavaBeans y los elementos de Java.util.Map (los cuales representan un conjunto de pares nombre/valor) pueden ser accedidos usando unas de la siguientes maneras:

En las primeras dos expresiones, podemos acceder a una propiedad llamada aProperty en un JavaBean o una entrada a Map con la clave aProperty. En la tercera expresi贸n (note que no hay comillas), tenemos acceso a un elemento de anObject con un nombre contenido en la variable aVariableContainingPropertyName:

${anObject.aProperty} ${anObject["aPropertyName"]} ${anObject[aVariableContainingPropertyName]} 108


Lenguaje de expresiones (EL)

Existe un numero de variables implícitas de EL:

Variable name

Description

pageScope

A collection (a Java.util.Map) of all page scope variables.

requestScope

A collection (a Java.util.Map) of all request scope variables.

sessionScope

A collection (a Java.util.Map) of all session scope variables.

applicationScope

A collection (a Java.util.Map) of all application scope variables.

param

A collection (a Java.util.Map) of all request parameter values as a single String value per parameter.

paramValues

A collection (a Java.util.Map) of all request parameter values as a String array per parameter.

header

A collection (a Java.util.Map) of all request header values as a single String value per header.

headerValues

A collection (a Java.util.Map) of all request header values as a String array per header.

cookie

A collection (a Java.util.Map) of all request cookie values as a single Javax.Servlet.http.Cookie value per cookie. A collection (a Java.util.Map) of all application initialization parameter values as a single String value per parameter.

initParam pageContext

An instance of the Javax.Servlet.jsp.PageContext class, providing access to various request data.

109

Lenguaje de expresiones (EL)

Los operadores describen lo que se desea hacer con las variables. Los operadores que se pueden usar en una expresión EL parecerán familiar si ya se ha utilizado algún lenguaje de programación antes, porque son parecidos a los utilizados por la mayoría de los lenguajes:

110


Lenguaje de expresiones (EL) Operator

Description

.

Access a Bean property or Map entry.

[]

Access an array or List element.

()

Group a subexpression to change the evaluation order.

?:

Conditional test: condition ? ifTrue : ifFalse.

+

Addition.

-

Subtraction or negation of a value.

*

Multiplication.

/ or div

Division.

% or mod

Modulo (remainder).

== or eq

Test for equality.

!= or ne

Test for inequality.

< or lt

Test for less than.

> or gt

Test for greater than.

<= or le

Test for less than or equal.

>= or ge

Test for greater than or equal.

&& or and

Test for logical AND.

|| or or

Test for logical OR.

! or not

Unary Boolean complement.

empty

Test for an empty variable value: null, an empty String, or an array, Map, or Collection without entries). A function call, where func is the function name and args is zero, one or more comma-separated function arguments.

func(args)

111

Bibliotecas de etiquetas JSTL

JSTL 1.1 fue pensado para acoplar JSTL con JSP 2.0. El cambio más visible es que el JSTL 1.0 “bibliotecas gemelas" (una que acepta expresiones EL y un conjunto que acepta expresiones de Java) han sido remplazadas por un conjunto sencillo de bibliotecas que pueden ser utilizadas tanto con EL o con expresiones Java. Cuando se importa cualquier biblioteca de etiquetas dentro de una página JSP, se define un prefijo que señala un espacio de nombres que corresponde a las etiquetas en esa biblioteca. Note que se podría definir sus propios prefijos, pero no existe una buena razón para esto. Las cuatro bibliotecas de etiquetas estándar, con sus convenciones de prefijos definidos JSTL, se enumeran en la diapositiva siguiente.

112


Bibliotecas de etiquetas JSTL

biblioteca

URI

Prefijo

Core

http://Java.sun.com/jstl/core-rt

c

XML processing

http://Java.sun.com/jstl/xml

x

I18N formatting

http://Java.sun.com/jstl/fmt

Database access

http://Java.sun.com/jstl/sql

Functions

http://Java.sun.com/jstl/functions

fmt sql fn 113

Bibliotecas de etiquetas JSTL

Otro punto por mencionar acerca de la biblioteca de etiquetas JSTL es que hay realmente dos versiones de la mayoría de las etiquetas. Un conjunto toma ventaja del nuevo lenguaje de expresiones y el otro no;

Las etiquetas que no hacen uso de un lenguaje de expresiones utilizan expresiones request-time :

Esto es útil si se desea la flexibilidad proporcionada por las etiquetas estándares pero no queremos utilizar el lenguaje de expresiones soportado aun,

Para tener acceso a estas bibliotecas, simplemente añada -rt al final del URI que señala a la biblioteca: <%@ taglib prefix="c" uri="http://java.sun.com/jstl/ea/core-rt" %> 114


Biblioteca de etiquetas JSTL

Para usar la biblioteca de etiquetas core del EL en una página, incluya la directiva del siguiente ejemplo en la parte superior de su página: <%@ taglib prefix="c" uri=http://java.sun.com/jstl/core-rt %>

Para usar las etiquetas que están en esa librería core, añada un prefijo a cada etiqueta en la página con el prefijo que se ha señalado en la declaración que se incluyó: <c:out value="${anExpression}"/> 115

Reglas más flexibles del formato de documentos JSP

La especificación JSP soporta dos tipos de páginas JSP:

páginas JSP regulares conteniendo cualquier tipo de texto o marcado y, Documentos JSP los cuales son documentos XML bien formados; es decir, documentos con elementos del XHTML y de JSP,

Para satisfacer los requerimientos de bien formado, las directivas JSP y los elementos scripting en un documento JSP deben estar escritos con una sintaxis diferente a la de una página regular JSP. 116


Reglas mรกs flexibles del formato de documentos JSP Pรกgina JSP regular

Documento JSP

<%@ page attribute list %>

<jsp:directive.page attribute list />

<%@ include file="path" %>

<jsp:directive.include file="path" />

<%! declaration %>

<jsp:declaration>declaration</jsp:declaration>

<%= expression %>

<jsp:expression>expression</jsp:expression>

<% scriptlet %>

<jsp:scriptlet>scriptlet</jsp:scriptlet>

117

Ejemplos JSTL Sencillos

118


Ejemplo (a)

Como ejemplo simple considere el siguiente fragmento de c贸digo que utiliza JSTL. La acci贸n set crea una variable llamada browser y le asigna el valor de la propiedad User-Agent. La acci贸n out imprime entonces el valor de la variable browser. <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %> <html> <head> <title>Ejemplo Simple</title> </head> <body> <c:set var="browser" value="${header['User-Agent']}"/> <c:out value="${browser}"/> </body> </html> 119

Ejemplo (a)

120


Ejemplo (b) <%@ taglib prefix="c" uri="http://Java.sun.com/jstl/core-rc" %> <html> <head> <title>Objetos implictos JSTL</title> </head> <body bgcolor="#FFFFCC"> <h3>Header info:</h3> <c:forEach var="head" items="${headerValues}"> param: <c:out value="${head.key}"/><br> values: <c:forEach var="val" items="${head.value}"> <c:out value="${val}"/> </c:forEach> <p> </c:forEach> </body> </html> 121

Ejemplo (b)

122


Etiquetas XML

XML esta siendo cada vez mas importante para los creadores de páginas y JSTL proporciona acciones XML que conducen las necesidades básicas de estos desarrolladores. Las acciones XML pueden ser divididas en core (núcleo), control de flujo (control flow) y acciones de transformación. Las acciones XML core son parecidas a las acciones proporcionadas por core discutidas anteriormente, e incluyen <x:out>, <x:set>, and <x:parse>. La principal diferencia entre las acciones core discutidas antes y las acciones XML core es que las acciones XML soportan expresiones XPath, mientras las acciones core no.

De hecho, las acciones XML están basan en expresiones XPath.

Xpath es un lenguaje para definir partes de un documento XML; XPath utiliza expresiones del tipo path para identificar nodos en un documento XML. 123

Etiquetas XML

Las acciones del flujo de control XML son las mismas que las acciones del core discutidas anteriormente. Estas incluyen: <x:if>, <x:choose>, <x:when>, <x:otherwise>, and <x:forEach>. La principal diferencia es que utilizan el atributo select para especificar expresiones XPath. ejemplo: <x:forEach select="$output/portfolio/stock"> <x:out select="price"/> </x:forEach> En la diapositiva siguiente xml-ex1.jsp utiliza las bibliotecas de etiquetas core y XML para procesar un documento XML.

En este ejemplo, el documento XML es incrustado dentro de la página y la etiqueta <x:parse> es utilizada para analizar el documento. Entonces una expresión XPath se utiliza para seleccionar artículos dentro del documento. 124


xml-ex1.jsp - i <%@ taglib prefix="c" uri="http://Java.sun.com/jstl/core-rt" %> <%@ taglib prefix="x" uri="http://Java.sun.com/jstl/x-rt" %> <html> <head><title>JSTL Support for XML</title></head> <h3>Books Info:</h3> <c:set var="xmltext"> <books> <book> <title>Book Title A</title> <author>A. B. C.</author> <price>17.95</price> </book> <book> <title>Book Title B</title> <author>X. Y. Z.</author> <price>24.99</price> </book> </books> </c:set> 125

xml-ex1.jsp – ii <x:parse xml="${xmltext}" var="output"/> <b>The title of the first book is</b>: <x:out select="$output/books/book[1]/title"/> <br> <b>The price of the second book</b>: <x:out select="$output/books/book[2]/price"/> </body> </html>

126


xml-ex2.jsp <%@ taglib prefix="c" uri="http://Java.sun.com/jstl/core-rt" %> <%@ taglib prefix="x" uri="http://Java.sun.com/jstl/x-rt" %> <html> <head> <title>JSTL Support for XML</title></head> <h3>Portfolio</h3> <c:import url="http://www.Javacourses.com/stocks.xml" var="xmldoc"/> <x:parse xml="${xmldoc}" var="output"/><p> <table border="2" width="50%"> <tr> <th>Stock Symbol</th> <th>Company Name</th> <th>Price</th> </tr> <tr> <x:forEach select="$output/portfolio/stock" var="item"> <td><x:out select="symbol"/></td> <td><x:out select="name"/></td> <td><x:out select="price"/></td></tr> </x:forEach> </table> </body> </html>

127

xml-ex2.jsp

128


Extendiendo el JSTL

También es posible que se pueda utilizar JSTL como base para desarrollar sus propias etiquetas. Algunas clases abstractas son proporcionadas de tal manera que asisten en el desarrollo rápido de etiquetas y promueven la integración de sus propios etiquetas personalizados con el conjunto de etiquetas JSTL. Por ejemplo, se puede construir sus propias etiquetas personalizados que hagan uso de los mecanismo EL de JSTL.

Mediante extender: Javax.Servlet.jsp.jstl.core.ConditionalTagSupport, se podría escribir una etiqueta condicional simplemente implementado un método que regrese un valor booleado correspondiente con el comportamiento condicional deseado de la etiqueta. o, Javax.Servlet.jsp.jstl.core.IteratorTagSupport, Le permite a implementar fácilmente etiquetas de iteración.

129

Desarrollando bibliotecas de etiquetas personalizadas como archivos de etiquetas

Comenzando con la versión 2.0 de la especificación JSP, las acciones personalizadas de la biblioteca de etiquetas pueden ser implementadas de dos maneras:

Como clases de java o, Como archivos de texto regular conteniendo elementos de JSP.

En versiones anteriores, las acciones personalizadas podían solamente ser implementadas como clases de java, dejándolas con esto fuera del alcance de los no programadores. Otro problema con la implementación en java de las acciones personalizadas es que era forzado a imprimir código HTML con llamadas a println() para producir contenido complejo – El mismo problema que JSP se supone que resuelve. 130


Creando y usando un archivo de etiquetas

Un archivo de etiquetas es un archivo de texto que contienen elementos JSP implementando la funcionalidad de acciones personalizadas. Se debe utilizar un archivo con extension .tag* para identificar este tipo de archivo en el contenedor Web. Todos los elementos JSP que se pueden utilizar en un archivo JSP también pueden ser utilizados como un archivo de etiqueta, con excepción a la directiva page (un archivo de etiqueta no es una página). También hay algunas directivas JSP que pueden ser permitidas en un archivo de etiquetas, como lo veremos mas adelante. Aparte de esto, crear un archivo de etiquetas no es diferente de crear una página JSP. Una vez creado e instalado, el archivo de etiquetas se utiliza igual que las acciones personalizadas implementadas en java que se han visto anteriormente. 131

Invocación de una etiqueta Obtain handler doStartTag() Set properties

setPageContext() setParent()

SKIP_BODY

EVAL_BODY_INCLUDE

Process body

Set attribute values SKIP_PAGE

doEndTag()

EVAL_PAGE

release()

release()

Stop

Continue

132


Un archivo de etiquetas sencillo copyright.tag <%@ tag body-content="empty" %> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %> <jsp:useBean id="now" scope="application" class="Java.util.Date" /> Copyright © ${now.year + 1900} My Company

Este archivo de etiquetas inserta una declaración de copyright con el año actual en la página que se llama. La primera línea es una directiva de etiqueta. Se puede utilizar atributos de esta directiva para especificar una descripción, un icono o un ejemplo, que una herramienta de desarrollo de páginas puede mostrar al diseñador. Otros atributos le permiten especificar si las expresiones EL deben ser procesadas, así como información relacionada al código del scripting, ejemplo: el mismo tipo de información que se especifico con la directiva page en las página JSP.

133

Nota de la etiqueta body-content

Un manejador de etiquetas para una etiqueta con un cuerpo es implementado de manera diferente dependiendo si el manejador de etiqueta necesita interactuar con el cuerpo o no:

Por interactuar, queremos decir que el manejador de etiqueta lee o modifica los contenidos del cuerpo o causa evaluación interactiva del cuerpo.

134


Un archivo de etiquetas sencillo

En la mayoría de los casos, los autores de archivos de etiquetas sólo se preocupan del atributo que define el contenido del cuerpo (body-content):

Este atributo dice cómo el cuerpo de la acción personalizada debe manejarse, y debe tener uno de los siguientes valores:

Si es empty (vació), el intentar usar el cuerpo de la acción personalizada da como resultado un error de sintaxis. El valor scriptless significa que el cuerpo puede contener algunos elementos JSP :

empty, scriptless (por defecto), o tagdependent.

En otras palabras, el texto de plantilla, las expresiones EL, las acciones estándares y las acciones personalizadas, todas son permitidas.

Si el atributo se establece a tagdependent el cuerpo del elemento de la acción es tratado como un texto de plantilla (ejemplo, los elementos de la acción y las expresiones EL en el cuerpo no son procesadas, son manejados como texto plano). 135

Un archivo de etiquetas sencillo

El resto del archivo de etiquetas luce como una página ordinaria JSP. Declara que utiliza la biblioteca JSTL core, una acción estándar <jsp:useBean> para crear una instancia de la clase Java.util.Date que representa la hora actual y finalmente hace salir el texto estático mezclado con un valor dinámico (el año actual) generado por la expresión EL: ${now.year + 1900}.*

136


Notas

Los archivos Tag pueden ser colocados directamente en la aplicación Web bajo la estructura del directorio o subdirectorio Web-INF/tags. Cada directorio que contiene archivos tag files representa un tag library separado: Web-INF/tags/ mytags/ copyright.tag forEvenAndOdd.tag htmlFormat.tag motd.tag myothertags/ foo.tag bar.tag

Aquí tenemos dos carpetas de tag: mytags y myothertags. La carpeta mytags contiene el archivo copyright.tag mas otros tres archivos tag. Por defecto, el nombre de las acciones implementadas personalizadas por el archivo tag es el nombre de archivo menos la extensión .tag, así que el archivo copyright.tag representa el nombre de la acción personalizada llamada copyright en la librería mytags. 137

Mas ejemplos

Una página JSP debe declarar que utiliza un tag library representada por los archivos tag en la estructura de la aplicación Web con una directiva ligeramente diferente que el usado anteriormente: <%@ page contentType="text/html" %> <%@ taglib prefix="my" tagdir="/Web-INF/tags/mytags" %> <html> <body bgcolor="white"> ... <my:copyright/> </body> </html> 138


Mas ejemplos

Note que el atributo tagdir es utilizado en lugar que el atributo del URI. El valor del atributo tagdir es la trayectoria relativa del contexto al directorio que contiene los archivos tag para la biblioteca. Puede parecer redundante tener que especificar la parte del path /Web-INF/tags, puesto que todos los directorios tag de la biblioteca deben comenzar con este path. Aunque es costoso, el grupo que creó la especificación JSP decidió requerir esto para tener consistencia con otros atributos que toman valores del path. Los archivos tag pueden ser empaquetados en archivos JAR.

Esto requiere un poco mas de trabajo y es sobre todo de interés para los archivos tag prever ser reutilizado en muchas aplicaciones.

139

El Tag Handler

Hay dos interfases que describen al tag handler:

Tag usado por los manejadores de etiquetas simples no interesados en la manipulación del contenido del cuerpo. BodyTag una extensión del tag dando acceso al manejador al cuerpo.

El Tag Handler tiene dos métodos de acción principales:

doStartTag() procesa el comienzo del tag de esta acción. doEndTag() procesa el final del tag de esta acción. Llamado después de retornar de doStartTag. release() libera recursos

140


Otros ejemplos Tags personalizados

141

Tag Handler Hola mundo

Las subclases simples de tag handler soportan la llamada a las clases SimpleTagSupport. Esta clase es una muy buena implementación de la interfase SimpleTag. Proporciona implementacion de los cinco métodos de esta interfaz, el más importante es el método doTag(). El método doTag() en SimpleTagSupport realmente no hace nada – hasta que el desarrollador sobreescribe este metodo y codifica la funcionalidad de su tag. El código en la diapositiva siguiente muestran este método en acción. 142


Tag Handler Hola mundo // Greeter.Java package mab; import Javax.Servlet.jsp.JspException; import Javax.Servlet.jsp.tagext.SimpleTagSupport; import Java.io.IOException; public class Greeter extends SimpleTagSupport { public void doTag() throws JspException, IOException { getJspContext().getOut().write( "Hello, world!" ); }

Compile y sustituya la clase en \Web-INF\classes\mab 143

Tag Handler Hola mundo

Esta clase utiliza simplemente doTag() para imprimir el ‘Hola mundo’ al stream de salida. Las dos declaraciones de importación nos dan acceso a todas las clases requeridas:

Usted necesitara el Servlet y las clases JSP API en su classpath para que este código compile: Los usuario de Tomcat encontrarán estos en common/lib como jasper-api.jar and Servlet-api.jar.

Por estas razones, esta clase extiende la clase SimpleTagSupport y espera que usted sobrescriba el método doTag(). 144


Tag Handler Hola mundo

Otra consecuencia de extender la clase es que un método llamado setJspContext() fue llamado por el contenedor antes del doTag(), que hizo la información actual del contexto del JSP disponible vía getJspContext(). Utilizamos este método para conseguir el acceso al stream de salida del JSP.

145

Tag Handler Hola mundo

Mapeo de tags a clases:

Asumimos que esta clase esta en /WebINF/classes, el siguiente paso debería escribir el archivo TLD. El TLD (Tag Library Descriptor) es un archivo XML que el contenedor utiliza para trazar los tags personalizados de sus JSPs a su correspondiente implementación de clases simples del tag handler. En la siguiente presentación veremos un demo.tld, un archivo simple del TLD, que cuando esta instalado en el directorio /WebINF/tags/mytags, traza una un tag llamado 'greeter' a la clase 'demo.mytags.tags.Greeter'. 146


Tag Handler Hola mundo <!– demo.tld --> <?xml version="1.0"?> <!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://Java.sun.com/j2ee/dtds/Web-jsptaglibrary_1_2.dtd"> <!-- demo.tld --> <taglib> <tlib-version>1</tlib-version> <jsp-version>1.2</jsp-version> <short-name>Demo Tag Library</short-name> <tag> <name>greeter</name> <tag-class>mab.Greeter</tag-class> <body-content>empty</body-content> </tag> </taglib> Drop this file in Web-INF/tags/mytags/ 147

Tag Handler Hola mundo

Mapeando Tags a clases:

Los elementos de tlib-version y short-name son bastante directos y se relacionan con la versión del tag library y con el prefijo por defecto del tag respectivamente. El elemento de uri, sin embargo vale la pena discutirlo: Cuando se inicializa, el contenedor usa una característica de auto-discovery para trazar todos los elementos de uri a TLD correspondiente; Por lo tanto esta cadena debe ser única dentro de la aplicación. As of JSP 1.2, nosotros no tenemos ninguna necesidad de editar el archivo Web.xml para desplegar un tag personalizado – la caracteristica del auto-discovery nos ahorra esta inconvenienza. La parte interesante es el contenido del elemento del <tag>. Es donde, entre otras cosas, nosotros podemos dar a nuestro tag un nombre, definir la clase asociado con el tag handler, y determinar si nuestro tag se le debe o no permitir acceso al contenido del cuerpo.

148


Tag Handler Hola mundo

Cortesía de las directivas taglib el atributo uri, tenemos dicho que el JSP esta donde esta nuestro archivo TDL y, por tanto, donde se localiza nuestra clase simple de la implementación del tag handler. El atributo uri traza directamente a uno de los mappings del contenedor creado cuando se inicializo; El contenedor traza alternadamente puntos a la información del TLD. Generalmente, esto se toma con cuidado, si el atributo uri no resuelve la traza al contenedor, se asume el path del archivo:

Esto es útil solo cuando los valores idénticos del uri se encuentran en diferentes archivos TLD. 149

Hello World Tag Handler

Este código muestra como podemos utilizar nuestra etiqueta greeter en un JSP:

<!-- greeter.jsp --> <?xml version="1.0"?> <jsp:root xmlns:jsp="http://Java.sun.com/JSP/Page" xmlns:c="http://Java.sun.com/jstl/core" xmlns:my="urn:jsptld:/Web-INF/tags/mytags/demo.tld" version="1.2"> <jsp:directive.page contentType="text/html"/> <html> <head><title>JSP Page</title></head> <body> <!-- prints Hello World. --> <my:greeter /> </body> </html> </jsp:root> 150


Tag Handler Hola mundo

Aquí esta mi comprensión de cómo trabaja el tag personalizado usando el tag "Hello world!" como ejemplo:

Cuando la página greeter.jsp es solicitada por primera vez, el servidor Tomcat traducirá la página JSP a una clase de Java, Cuando el tag personalizado <my:greeter/>es encontrado durante la traducción, el servidor Tomcat hará un seguimiento del archivo TLD para localizar al archivo Greeter.class : Observe que el archivo TLD es proporcionado en el elemento jsp:root. Después el servidor Tomcat sustituirá el tag personalizado con un cierto código de Java al instanciar un objeto de la clase tag, inicializara el objeto y llamara al método doTag() . Para obtener datos de salida en la página, usted puede usar el stream del objeto pageContext proporcionado por la extinción tag JSP, pageContext.getOut(): Esta es la manera de como "Hello world!" es producido. 151

Ejemplo final de Tag

152


Ejemplo final de Tag

153

Ejemplo final de Tag

154


Ejemplo final de Tag

155

Ejemplo final de Tag

Los pasos usados por la extensiรณn JSP para facilitar el procesamiento de los tag personalizados pueden ser resumido como sigue:

Instanciamiento del objeto tag, Llamando a setPageContext() y setParent() del objeto tag, Procesando los atributos del tag. Ver mis otras notas sobre como los valores de los atributos son pasados al objeto tag, Llamando a doStartTag() del objeto tag, que puede retornar una bandera a la peticiรณn para saltar el cuerpo y realizar una lรณgica condicional del cuerpo, Procesamiento del cuerpo del tag, Llamando a doAfterBody() del objeto tag, que puede retornar una bandera a la peticiรณn para procesar el cuerpo otra vez y realizar un ciclo lรณgico del cuerpo, Llamando a doEndTag() del objeto tag, Llamando a release() del objeto tag.

156


Open Source Tag Libraries

ver http://jakarta.apache.org/taglibs:

Internationalization, Database access, Sending Mail, JNDI, Data/time, Populating/validating fields, Per regular expressions, Extracting data from other Web pages XSL transformations, And so on‌ 157

Open Source Tag Libraries

158


Integrando Servlets y JSPs

159

Porque combinar Servlets y JSPs?

Panorama: Se trata de usar JSP para hacer más fácil el desarrollo y mantenimiento de contenido HTML:

Para código dinámico simple, llamar código del Servlet desde expresiones scripting, Para casos moderadamente complejos, utilizar clases personalizadas llamadas expresiones scripting, Para casos mas complicados, use Beans y tags personalizados.

Pero, eso no es suficiente:

Para procesamiento complejo, JSP es lento, Aún con la conveniencia de separar clases, Beans y tags personalizados. La asunción detrás es que una página sencilla de una apariencia sencilla.

160


Arquitectura

Enfoque:

La petición original es contestada por el Servlet, El Servlet proceso los datos solicitados, hace búsquedas en la base de datos, accede a la lógica del negocio, etc. La petición se remite a una página JSP para darle formato a los resultados, Diferentes páginas JSP pueden ser usadas para manejar diferentes tipos de formatos.

Terminología:

A menudo llamada la arquitectura “Model View Controller” es una aproximación a JSP. Algo formalizado lo podemos ver en Apache “struts” framework – http://jakarta.apache.org/structs

161

Apache Struts

162


Enviando peticiones

Primero, llamar al método getRequestDispatcher de ServletContext:

Proveer un URL relativo a la raíz de las aplicaciones Web. Ejemplo: String url = “/presentations/presentation1.jsp”; RequestDispatcher dispatcher = getServletContent().getRequestDispatcher(url);

En segundo lugar:

Llamar a forward para transferir completamente el control a la página destino – vea el ejemplo siguiente. Llama a include para insertar la salida de la página destino y continuar.

163

Enviando peticiones: Código ejemplo. public void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { String operation = request.getParameter(“operation”); if (operation == null) operation = “unknown”; if (operation.equals(“operation1”)) { gotoPage(“/operations/presentation1.jsp”, request, response); } else if (operation.equals(“operation2”)) { gotoPage(“/operations/presentation2.jsp”, request, response); } else { gotoPage(“/operations/unknownRequestHandler.jsp”, request, response); }

164


Enviando peticiones: Código ejemplo.(cont..)

public void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { ReuestDispatcher dispatcher = getServletContext(). getRequestDispatcher(address); dispatcher.forward(request, response); }

165

Almacenar datos para uso posterior: El objeto session

Propósito:

Almacenar los datos que el Servlet buscó y que la página JSP utilizará en esta petición y en las peticiones siguientes del mismo cliente

Sintaxis del Servlet para almacenar datos: SomeClass value = new SomeClass(…); Session.setAttribute(“key”, value); // Use RequestDispatcher to forward to the JSP page.

166


Almacenar datos para uso posterior: : The Servlet Context

Propósito:

Almacenar los datos que el Servlet buscó y que la página JSP utilizara en esta petición y en las peticiones siguientes del mismo cliente Sintaxis del Servlet para almacenar datos :

SomeClass value = new SomeClass(…); Get ServletContext().setAttribute(“key”, value); //Use RequestDispatcher to forward to JSP page

167

On-line Travel Agent

168


Resumen JSP

169

Descripción

JSP hace mas fácil el crear y mantener HTML, mientras que provee un acceso total al código del Servlet. Las páginas JSPs son traducidas a Servlets:

Lo que usted necesita entender sobre Servlets:

Es el Servlet el que se ejecuta al momento de una petición. Para el cliente es totalmente transparente. Comprender como trabaja realmente JSP. El código del Servlet es llamada desde el JSP. El saber cuenco los Servlets son mejores que los JSP. Combinar Servlets y JSPs.

Otras tecnologías tienen un acercamiento similar pero no son portables y no le permiten usar Java para el código verdadero. 170


Ejemplo:

Combinando JSP + JavaBeans + JDBC

171

Ejemplos: JSP, JDBC Este ejemplo involucra a dos p谩ginas JSP (alumnos.jsp y verificaalumnos.jsp) , y un Java Bean -clase- (alumnos.java). Lo que hace el ejemplo es mostrar una lista de alumnos que se carga de la base de datos (agendita), y permite registrar nuevos alumnos. Nota: no existe ninguna validaci贸n de que el alumno ya exista, de hecho ni siquiera existe una llave primaria en la tabla. El ejemplo hace uso del JavaBean para manipular la tabla de alumnos, con un scope a nivel de aplicaci贸n. El tipo de base de datos utilizada es MySQL: Tabla Alumnos: nombre: varchar(30) apellido: varchar(30) direccion: varchar(30) telefono: varchar(30) 172


Ejemplos: JSP y Java Beans

<html> <head> <title>Alumnos</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <%@ page import="java.sql.*" %>

<jsp:useBean id="alum" class="dcc.alumnos" scope="application" />

Alumnos.jsp

</head> <body bgcolor="#FFCCCC"> <div Id="scroll" Style="position:absolute; left:78px; top:50px; width=570; height=420; overflow = auto; border=solid thin #B8D0F0; visibility:visible; z-index:2;; width: 813px; height: 518px"> <p align="center"><strong><font face="Georgia, Times New Roman, Times, serif" color="#000099">Lista de Alumnos</font><font face="Arial" color="#408080" > </font></strong></p> <%

Connection con; String url= "jdbc:mysql://localhost/agendita"; String usuario= "bingo"; String password="holahola"; Statement stmt; ResultSet rs; try { Class.forName("com.mysql.jdbc.Driver").newInstance(); con = DriverManager.getConnection(url,usuario,password); alum.setCn(con); stmt = con.createStatement(); %> <table border="1" cellpadding="0" cellspacing="1" width="100%"> <tr> <td align="center" bgcolor="#0068C0"><font face="Arial" color="#FFFFFF">Nombre</font></td> <td align="center" bgcolor="#0068C0"><font face="Arial" color="#FFFFFF">Apellido</font></td> <td align="center" bgcolor="#0068C0"><font face="Arial" color="#FFFFFF">Direccion</font></td> <td align="center" bgcolor="#0068C0"><font face="Arial" color="#FFFFFF">Telefono</font></td> </tr>

173

<% rs = stmt.executeQuery("Select * from alumnos"); while(rs.next()) {%> <tr> <td bgcolor="#B8D0F0"><small><font face="Arial"><%=rs.getString("nomrbe")%></font></small></td> <td bgcolor="#B8D0F0"><small><font face="Arial"><%=rs.getString("apellido")%></font></small></td> <td bgcolor="#B8D0F0"><small><font face="Arial"><%=rs.getString("direccion")%></font></small></td> <td bgcolor="#B8D0F0"><small><font face="Arial"><%=rs.getString("telefono")%></font></small></td> </tr> <%}%> </table> <% } catch(Exception e) { System.out.println("Error al conectarse: "+e.toString()); }%> <form name="form1" method="post" action="VerificaAlumnos.jsp"> <p align="center"><strong><font face="Georgia, Times New Roman, Times, serif" color="#000099">Registro de Alumnos</font><font face="Arial" color="#408080" > </font></strong></p> <table border="1" cellpadding="0" cellspacing="1" width="100%"> <tr> <td bgcolor="#B8D0F0" width="27%"><small><font face="Arial">Nombre</font></small></td> <td width="73%" align="center" bgcolor="#B8D0F0"><small><font face="Arial"> <input type="text" name="nombre" size="80" maxlength="75"> </font></small> </td> </tr> <tr> <td bgcolor="#B8D0F0" width="27%"><small><font face="Arial">Apellido</font></small></td> <td width="73%" align="center" bgcolor="#B8D0F0"><small><font face="Arial"> <input type="text" name="apellido" size="80" maxlength="75"> </font></small> </td> </tr>

174


<tr> <td bgcolor="#B8D0F0" width="27%"><small><font face="Arial">Direccion</font></small></td> <td width="73%" align="center" bgcolor="#B8D0F0"><small><font face="Arial"> <input type="text" name="direccion" size="80" maxlength="75"> </font></small> </td> </tr> <tr> <td bgcolor="#B8D0F0" width="27%"><small><font face="Arial">Telefono</font></small></td> <td width="73%" align="center" bgcolor="#B8D0F0"><small><font face="Arial"> <input type="text" name="telefono" size="80" maxlength="75"> </font></small> </td> </tr> </table> <br> <center> <input type="submit" name="btnContinuar" value="Registrar"> </center> </form> </div> </body> </html>

175

VerificaAlumnos.jsp <html> <head> <title>Alumnos</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> </head> <%@ page import="java.sql.*" %> <jsp:useBean id="alum" class="dcc.alumnos" scope="application" />

<body bgcolor="#FFCCCC"> <div Id="scroll" Style="position:absolute; left:259px; top:122px; width=570; height=420; overflow = auto; border=solid thin #B8D0F0; visibility:visible; z-index:2;; width: 509px; height: 183px"> <br> <table border="0" cellpadding="0" cellspacing="1" width="100%"> <tr> <td width="40%" align="center" bgcolor="#0068C0"><font face="Arial" color="#FFFFFF"><b><font face="Georgia, Times New Roman, Times, serif">Resultados</font></b></font></td> <tr> </tr> </table>

176


<br> <jsp:setProperty <jsp:setProperty <jsp:setProperty <jsp:setProperty

name="alum" name="alum" name="alum" name="alum"

property="nombre" param="nombre"/> property="apellido" param="apellido"/> property="direccion" param="direccion"/> property="telefono" param="telefono"/>

<% if (alum.NuevoAlumno()) { %> <p align="center"><strong><font face="Georgia, Times New Roman, Times, serif" color="#000099">El alumno</font><font face="Arial" color="#408080" >  <jsp:getProperty name="alum" property="nombre" />  <jsp:getProperty name="alum" property="apellido" />   <font face="Georgia, Times New Roman, Times, serif" color="#000099">se registro correctamente!!!</font> </font></strong></p> <% } else { %> <p align="center"><strong><font face="Arial" color="#408080" > <font face="Georgia, Times New Roman, Times, serif" color="#000099">Se ha generado un error y no se grabo el alumno</font>  <jsp:getProperty name="alum" property="nombre" />  <jsp:getProperty name="alum" property="apellido" />   <font face="Georgia, Times New Roman, Times, serif" color="#000099">Verifique...! </font> </font></strong></p> <% } %> <form name="form1" method="post" action="Alumnos.jsp"> <center> <input type="submit" name="btnContinuar" value="Continuar"> </center> </form> </div> </body> </html>

177

Bean Alumnos.java package dcc; import java.sql.*; public class alumnos { private String nombre; private String apellido; private String direccion; private String telefono; private Connection cn; public void setCn(Connection cn) { this.cn=cn; } public Connection getCn() { return(cn); } public void setNombre(String nombre) { this.nombre=nombre; } public String getNombre() { return(nombre); }

public void setApellido(String apellido) { this.apellido=apellido; } public String getApellido() { return(apellido); } public void setDireccion(String direccion) { this.direccion=direccion; } public String getDireccion() { return(direccion); } public void setTelefono(String telefono) { this.telefono=telefono; } public String getTelefono() { return(telefono); }

178


public boolean isAlumno(String nombre) { Statement st; String sqlQuery; if (cn!=null) { try { st= cn.createStatement(); sqlQuery="Select * from alumnos where nomrbe='"+nombre.trim()+"'"; ResultSet rs=st.executeQuery(sqlQuery); if (rs.next()) { this.nombre=nombre; apellido=rs.getString("apellido").trim(); direccion=rs.getString("direccion").trim(); telefono=rs.getString("telefono").trim(); rs.close(); return(true); } else { this.nombre=""; apellido=""; direccion=""; telefono=""; rs.close(); return (false); } }

179

//try catch(SQLException e) { this.nombre=""; apellido=""; direccion=""; telefono=""; return (false); } } else return(false); } public boolean NuevoAlumno() { Statement st; String sqlInsert; if (cn!=null) { try { st= cn.createStatement(); sqlInsert="INSERT INTO alumnos VALUES('"+ nombre.trim() + "','"+ apellido.trim()+"','"+direccion.trim()+"','"+telefono.trim()+"')"; st.executeUpdate(sqlInsert); return(true); } catch(SQLException e) { return(false); } } else return(false); } }

180


Turn static files into dynamic content formats.

Create a flipbook
Issuu converts static files into: digital portfolios, online yearbooks, online catalogs, digital photo albums and more. Sign up and create your flipbook.