Download Java Server Pages JSP
Document related concepts
no text concepts found
Transcript
Java Server Pages JSP Otra forma de hacer servlets Las JSP • Son páginas HTML a las que se le inserta código que produce servlets • Se usan cuando la parte estática de la página que se debe generar es relativamente importante (la parte que no cambia) • Al cargarse una página JSP esta se compila, se genera el servlet y se ejecuta • Por esto, la primera invocación a una JSP demora más que las siguientes Contenido de una JSP • Una JSP, aparte de código HTML puede contener 3 tipos de constructos : – Elementos de scripting: son los elementos que definen el comportamiento dinámico del servlet, es decir su código – directivas: afectan la estructira general del servlet que resulta de la JSP – acciones: permiten redirigir el request a otra instancia JSP, servlet o página HTML Elementos de scripting • 1. Expresiones de la forma <%= expresión %>, son evaluadas e insertadas en el output del servlet • 2. Scriptlets de la forma <% code %>, que son insertadas en el método _jspService el cual es el método llamado cuando se contacta a la página jsp • 3. Declaraciones de la forma <%! code %>, que son insertadas en el cuerpo de la clase del servlet, fuera de todo método, definiendo así variables de instancia Variables predefinidas • Para simplificar las expresiones, existen variables predefinidas que se pueden usar. Las más importantes son: – – – – request, el HttpServletRequest response, el HttpServletResponse session, el HttpSession asociada al request out, el PrintWriter usado para mandar output al cliente Un Ejemplo (Ejemplo1.jsp) <HTML> <HEAD> <TITLE>JSP Expressions</TITLE> </HEAD> <BODY> <H2>JSP Expressions</H2> <UL> <LI>Current time: <%= new java.util.Date() %> <LI>Your hostname: <%= request.getRemoteHost() %> <LI>Your session ID: <%= session.getId() %> <LI>The <CODE>testParam</CODE> form parameter: <%= request.getParameter("testParam") %> </UL> </BODY> </HTML> Explicaciones • El servidor crea un servlet, lo compila y llama al método _jspService que contiene todas las sentencias escritas entre <% y %> • El texto HTML es mandado al cliente por vía out.print(....) • Las expresiones se evalúan y se insertan en el texto que se manda, por lo cual la expresión <LI>Current time: <%= new java.util.Date() %> equivaldría en un servlet a hacer out.println(“<LI>Current time: “+ new java.util.Date() ); Scriptlets • Si se quiere hacer algo más complicado que insertar una simple expresión en el output del servlet se pueden incluir sentencias JAVA en scriptlets que tienen la siguiente estructura: <%String queryData = request.getQueryString(); out.println("Attached GET data: " + queryData); %> • Los Scriptlets tienene acceso a a las mismas variables definidas automáticamente a las que tienen acceso las expresiones • En particular, esto también se pudo haber logrado con Attached GET data: <%= request.getQueryString() %> pero hay cosas que no se pueden hacer con expresiones: <% response.setContentType("text/plain"); %> Algo más serio (Ejemplo2.jsp) <HTML> <HEAD> <TITLE>Color Testing</TITLE> </HEAD> <% String bgColor = request.getParameter("bgColor"); boolean hasExplicitColor; if (bgColor != null) { hasExplicitColor = true; } else { hasExplicitColor = false; bgColor = "WHITE"; } %> <BODY BGCOLOR="<%= bgColor %>"> <H2 ALIGN="CENTER">Color Testing</H2> <% if (hasExplicitColor) out.println("You supplied color " +bgColor ); else out.println("Using background color WHITE.."); %> Usando Scriptlets para hacer partes del archivo JSP condicional Para entender esto hay que tener claro que el contenido de un scriptlet se incluye exactamente como está escrito al método _jspService y las sentencias HTML se traducen como un out.println(...contenido de sentencia HTML...) en el mismo orden en que aparecen en la página jsp Scriptlets para hacer partes del archivo JSP condicional Por lo tanto, lo siguiente <% if (Math.random() < 0.5) { %> Have a <B>nice</B> day! <% } else { %> Have a <B>lousy</B> day! <% } %> se traduce en if (Math.random() < 0.5) { out.println(“Have a <B>nice</B> day!”); } else { out.println(“Have a <B>lousy</B> day! “); } El equivalente en XML El código equivalente para declarar scriptles pero siguiendo las reglas XML de <% Code %> es <jsp:scriptlet> Code </jsp:scriptlet> Esta forma de incluir sentencias jsp en la página HTML es muy recurrente, más adelante veremos otros jsp:setProperty: para definir propiedades a un bean jsp:include: para incluir otros archivos jsp:forward: para redirigir el request jsp:param: para definir parámetros a applets Deaclaraciones • No generan output, se usan para eclarar variables que más tarde serán usadas en expresiones o scriptlets • Una declaración tiene la siguiente forma: <%! Java Code %> Un ejemplo (Ejemplo3.jsp) que cuenta cuantas veces ha sido accesada una página desde que se cargó: <%! private int accessCount = 0; %> Accesses to page since server reboot: <%= ++accessCount %> El equivalente en XML El código equivalente para declaraciones pero siguiendo las reglas XML de <%! Code %> es <jsp:declaration> Code </jsp:declaration> Directivas • Afectan la estructura general del servlet generado • Existen 3 tipos de directivas: page, include y taglib <%@ directiva atributo="valor" %> <%@ directiva atributo1="valor1" atributo2="valor2" ... atributoN="valorN" %> Directiva page • Permite controlar la estructura del servlet importando clases, afinando la superclase, definiendo el tipo de contenido a enviar, etc. • Esto se hace definiendo uno o más de los siguientes atributos: – import, contentType, isThreadSafe, session, buffer, autoflush, extends, info, errorPage, isErrorPage y language. • Veremos import, contentType, errorPage e isErrorPage El atributo import • Permite importar clases que no se incluyen automáticamente • Por ejemplo, se pueden importar las usuales para java (java.util.*) • Para las clases definidas por el programador, estas deben estar en un lugar “visible”. Este lugar depende del servidor • En tomcat es el mismo directorio en donde están los servlets (Ejemplo4.jsp con ServletUtilities.java y LongLivedCookie.java) <%@ page import=”java.util.*" %> <%@ page import="package.class1,..., package.classN" %> Controlando el tipo de salida • Se hace a través de la directiva <%@ page contetType=”text/plain" %> • Se puede usar para determinar cualquier tipo de salida que no sea text/html • Puede ir en cualquier parte del archivo, a pesar de que en un servlet esto debe ir antes de mandar cualquier cosa. Esto es porque primero la página se compila, traduce y luego se ejecuta en el orden adecuado de las directivas <HTML> <BODY> <H2>The contentType Attribute</H2> <%@ page contentType="text/plain" %> Esto debe verse como texto plano <B>no</B> como HTML. </BODY> </HTML> Generando salida para excel • Se hace a través de la misma directiva pero cambiando el tipo de salida que se generará (ejemplo5.jsp) <%@ page contentType="application/vnd.ms-excel" %> <%- entre columnas poner tabs, no espacios.-%> 1997 1998 1999 2000 2001 (Anticipated) 12.3 13.4 14.5 15.6 16.7 • Tambien se puede lograr lo mismo escribiendo código HTML para generar una tabla pero poner en la directiva que el contentType es ms-excel (ejemplo6.jsp) <TABLE BORDER=1> <TR><TH></TH><TH>Apples<TH>Oranges <TR><TH>First Quarter<TD>2307<TD>4706 <TR><TH>Second Quarter<TD>2982<TD>5104 <TR><TH>Third Quarter<TD>3011<TD>5220 <TR><TH>Fourth Quarter<TD>3055<TD>5287 </TABLE> errorPage & isErrorPage • Es posible invocar una determinada página cuando en otra sucede un error (se lanza una Exception ) • Para ello hay que poner en la página que puede generar el ellror la directiva <%@ page errorPage=”una_URL_relativa" %> • En la página que debe recibir el control (una_URL_relativa) debe ponerse lo siguiente <%@ page isErrorPage="true" %> (ver generaError.jsp y muestraError.jsp) Incluyendo otros archivos • Es posible hacerlo al momento en que se compila la página con la directiva <%@ include file=”nombre del archivo" %> • Esto implica que se incluirá el archivo referenciado como parte del actual antes de compilarlo • El problema es que si el archivo referenciado cambia, no cambiará en la página que se muestra (a menos que se reinicie el servidor) (ver contacto.jsp y pprincipal.jsp) • Se puede hacer que cada vz que se referencie la página incluida se vuelva a recargar el contenido con la siguiente directiva <jsp:include page=”nombre del archivo" flush="true" /> (ver noticias.jsp e item1.html, item2.html, item3.html) Incluyendo Applets • Con JSP es posible poner applets en una pagina web pero que son interpretadas por un plugin y no por el browser • Esto soluciona muchos problemas de versionamiento, ya que no todos los prowsers son capaces de interpretar applets compilados con una version de Java maor que 1.1.x • El elemento jsp:plugin instruye al server para que construya un plugin apropiado para interpretar el objeto. <jsp:plugin type="applet" code="Clock2.class" codebase="/directorio_relativo" jreversion="1.2" width="160" height="150" > <jsp:fallback> Plugin tag OBJECT or EMBED not supported by browser. </jsp:fallback> </jsp:plugin> • Ver ejemplo plugin de tomcat Java Beans • Usar Beans es una buena manera de complementar JSP cuando se requiere de estructuras de datos (clases) que hagan cosas más complejas, y separar el código de programación de estas clases de la JSP • Un Bean es una clase con las siguientes características: – Tiene un constructor que no tiene parámetros – No tiene variables públicas – Para cierto subconjunto de variables privadas llamadas propiedades, si la variable es de tipo tipo1 y se llama variable1entonces existe un método programado tipo1 getVariable1() que retorna el valor actual de la propiedad y otro void setVariable1(tipo1 x) que modifica el valor de la variable con el que está dado como parámetro Usando Beans en JSP • Para poder usar Beans con JSP en Tomcat estos deben ir en el mismo directorio que los servlets • Creación – <jsp:useBean id=’bean1' class=’Nombre_Clase' scope=“validez”/> • Es lo mismo que haber hecho en un programa Java – Nombre_Clase bean1 = new Nombre_Clase(); • Obtención de valores – <jsp:getProperty name=”bean1" property=”variable1" /> – <%= book1.getVariable1() %> • Modificación valores – <jsp:setProperty name=”bean1” property=”variable1” value=”valor1" /> – <% book1.setVariable1(”valor1"); %> Ejemplos JSP • Ver Date.jsp usa las sentencias jsp:getProperty • Numberguess.jsp usa los métodos set y get (y otros) directamente • Carts.jsp implementa un “carrito de compras” • forward.jsp muestra como se puede derivar el request a otra página