java – jsp

Post on 02-Jan-2016

34 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

DESCRIPTION

JAVA – JSP. JAVA SERVER PAGES PODSTAWY. Java EE training: http://courses.coreservlets.com. Źródło strony JSP. - PowerPoint PPT Presentation

TRANSCRIPT

1

JAVA – JSP

Java EE training: http://courses.coreservlets.com

JAVA SERVER PAGES PODSTAWY

2

Źródło strony JSP<%--

Document : index

Created on : 2008-12-15, 15:47:11

Author : Paolo

--%>

<%@page contentType="text/html" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

"http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>JSP Page</title>

</head>

<body>

<h1>Hello World!</h1>

</body>

</html>

3

Wygenerowany servletpackage org.apache.jsp;

import javax.servlet.*;

import javax.servlet.http.*;

import javax.servlet.jsp.*;

public final class index_jsp extends org.apache.jasper.runtime.HttpJspBase

implements org.apache.jasper.runtime.JspSourceDependent {

private static final JspFactory _jspxFactory = JspFactory.getDefaultFactory();

private static java.util.Vector _jspx_dependants;

private org.apache.jasper.runtime.ResourceInjector _jspx_resourceInjector;

public Object getDependants() {

return _jspx_dependants;

}

public void _jspService(HttpServletRequest request, HttpServletResponse response)

throws java.io.IOException, ServletException {

......

}

4

Metoda _jspService standardowe zmienne lokalne

....

PageContext pageContext = null;

HttpSession session = null;

ServletContext application = null;

ServletConfig config = null;

JspWriter out = null;

Object page = this;

JspWriter _jspx_out = null;

PageContext _jspx_page_context = null;

try {

response.setContentType("text/html;charset=UTF-8");

response.setHeader("X-Powered-By", "JSP/2.1");

pageContext = _jspxFactory.getPageContext(this, request, response, null, true, 8192, true);

_jspx_page_context = pageContext;

application = pageContext.getServletContext();

config = pageContext.getServletConfig();

session = pageContext.getSession();

out = pageContext.getOut();

_jspx_out = out;

_jspx_resourceInjector = (org.apache.jasper.runtime.ResourceInjector) application.getAttribute("com.sun.appserv.jsp.resource.injector");

......

}

5

Metoda _jspService cd. ....

out.write("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\"\n");

out.write(" \"http://www.w3.org/TR/html4/loose.dtd\">\n");

out.write("\n");

out.write("<html>\n");

out.write(" <head>\n");

out.write(" <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\">\n");

out.write(" <title>JSP Page</title>\n");

out.write(" </head>\n");

out.write(" <body>\n");

out.write(" <h1>Hello World!</h1>\n");

out.write(" </body>\n");

out.write("</html>\n");

} catch (Throwable t) {

if (!(t instanceof SkipPageException)){

out = _jspx_out;

if (out != null && out.getBufferSize() != 0)

out.clearBuffer();

if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);

}

} finally {

_jspxFactory.releasePageContext(_jspx_page_context);

}

}......

6

Predefiniowane zmiennerequest– Pierwszy argument metody do obsługi parametrów żądania (typ obiektu HttpServletRequest)

response– Drugi argument metody do obsługi odpowiedzi (typ obiektu HttpServletResponse )

out– Obiekt do generowania odpowiedzi przez servlet, (typ obiektu JspWriter)

wykorzystuje buforowanie

session– Obiekt do obsługi mechanizmu sesji związanej z żądaniem (typ obiektu HttpSession)

Mechanizm sesji może być wyłączony przez dyrektywę „page”

application– obiekt do obsługi zmiennych dostępnych w całej aplikacji webowej (typ obiektu ServletContext)

Dostęp uzyskany jest przez metodę getServletContext().

7

Elementy stron jsp

• Skryptlety <% … %>

• Komentarze <%-- … --%>

• Dyrektywy <%@ … %>

• Deklaracje <%! … %>

• Wyrażenia <%= … %>

• Akcje <jsp: …>

8

Wyrażenia (Expressions)

out.print( MyElements.JSPElement.Add(2, 3) );

<%= MyElements.JSPElement.Add(2, 3) %>

out.print( new MyElements.JSPElement().Subtract(2, 3) );<%= new MyElements.JSPElement().Subtract(2, 3) %>

public class JSPElement {

public static double Add(double a, double b)

{

return a+b;

}

public double Subtract(double a, double b)

{

return a-b;

}

}

9

Wyrażenia cd (Składnia XML)

Uwaga nie można mieszać znaczników XML ze standardowymi na jednej stronie

<jsp:expression>Java Expression</jsp:expression>

10

Skryplety

Format

– <% Java Code %>

• Wynik

Kod zostaje wstawiony Bezpośrednio do metody _jspService

Przykład

<%

String queryData = request.getQueryString();

out.println(" Parametry zadania GET " + queryData);

%>

<% response.setContentType("text/plain"); %>

Składnia w formacie XML

<jsp:scriptlet>Java Code</jsp:scriptlet>

11

Skryplety przykład<!DOCTYPE …>

<HTML>

<HEAD>

<TITLE>Color Testing</TITLE>

</HEAD>

<%

String bgColor = request.getParameter("bgColor");

if ((bgColor == null)||(bgColor.trim().equals(""))){

bgColor = "WHITE";

}

%>

<BODY BGCOLOR="<%= bgColor %>">

<H2 ALIGN="CENTER">Test zmiany koloru tła

"<%= bgColor %>".</H2>

</BODY></HTML>

12

Skryplety właściwości•Skryplety są wstawiane w servlet dokładnie tak jak zostały napisane,

•Niekoniecznie muszą tworzyć pełne wyrażenia w języku Java,

•Jednak pełne wyrażenia są barziej przejżyste łatwiejsze do analizy

Przykład:<% if (Math.random() < 0.5) { %>

Have a <B>nice</B> day!

<% } else { %>

Have a <B>lousy</B> day!

<% } %>

Kod wynikowy w servlecie– if (Math.random() < 0.5) {

out.println("Have a <B>nice</B> day!");

} else {

out.println("Have a <B>lousy</B> day!");

}

13

DeklaracjeFormat

<%!Java Code %>

Wynik

Kod jest wstawiany do definicji klasy servletu poza istniejącymi metodami

Przykład

<%! private int someField = 5; %>

<%! private void someMethod(...) {...} %>

Składnia w formacie XML

<jsp:declaration>Java Code</jsp:declaration>

Uwagi:

Pola są użyteczne. Deklaracje metod lepiej jest definiować w osobnych klasach

14

Deklaracje: przykład Kod strony JSP

<H1>Some Heading</H1>

<%!

private String randomHeading() {

return("<H2>" + Math.random() + "</H2>");

}

%>

<%= randomHeading() %>

15

Deklaracje: PrzykładKod Servletu

public class xxxx implements HttpJspPage {

private String randomHeading() {

return("<H2>" + Math.random() + "</H2>");

}

public void _jspService(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

response.setContentType("text/html");

HttpSession session = request.getSession();

JspWriter out = response.getWriter();

out.println("<H1>Some Heading</H1>");

out.println(randomHeading());

...

} ...

} // koniec servletu

16

Delklaracje Przykład 2<!DOCTYPE …>

<HTML>

<HEAD>

<TITLE>JSP Declarations</TITLE>

<LINK REL=STYLESHEET

HREF="JSP-Styles.css"

TYPE="text/css">

</HEAD>

<BODY>

<H1>JSP Declarations</H1>

<%! private int accessCount = 0; %>

<H2>Accesses to page since server reboot:

<%= ++accessCount %></H2>

</BODY></HTML>

17

Metody init i destroy w stronach JSP

Strony JSP mogą wymagać wywołania metod init i destroy

Servlet wygenerowny ze strony JSP może już wykorzystywać te funkcje

Nie można więc wykorzystać deklaracji do ich zdefiniowania, gdyż spowoduje to problemy

Rozwiązanie:

Przeładwać funkcje jspInit i jspDestroy.

Automatycznie generowane servlety wywołują te funkcje, których ciało w wersji podstawowej jest puste

18

Dyrektywy

<%@ method = ” ...”%>

19

Dyrektywa page import

Format<%@ page import="package.class" %>

<%@ page import="package.class1,...,package.classN" %>

WynikDodaje instrukcje import do definicji servletu

UwagiKlasy wykorzystywane przez strony JSP muszą być zawarte w pakietach (czyli umieszczoene w odpowiednich katalogach np..:

…/WEB-INF/classes

Przykład<%@ page import="java.util.*,coreservlets.*" %>

20

Dyrektywa page contentType

Format<%@ page contentType="MIME-Type" %>

<%@ page contentType="MIME-Type; charset=Character-Set" %>

<%@ page pageEncoding="Character-Set" %>

WynikOkreśla tym MIME strony generowanej przez servlet utworzony na podstawie definicji strony JSP

Uwagi– Wartość atrybutu nie może być określona podczas obsługi żądania

Przykład<%@ page contentType="application/vnd.ms-excel" %>

21

Dyrektywa page contentType cd

Ustawienie atrybutu contentType nie może być wyrażeniem warunkowycm

Poniższy kod powoduje ustawienie typu MIME (application/vnd.ms-excel) niezależnie od parametrów żądania

<% boolean usingExcel = checkUserRequest(request); %>

<% if (usingExcel) { %>

<%@ page contentType="application/vnd.ms-excel" %>

<% } %>

Trzeba wykorzystać skryplet i wywołać metodę response.setContentType

<%

String format = request.getParameter("format");

if ((format != null) && (format.equals("excel"))) {

response.setContentType("application/vnd.ms-excel");

}

%>

22

Dyrektywa page sessionFormat

<%@ page session="true" %> <%-- Default --%>

<%@ page session="false" %>

Wynik

Określa czy na dana strona implementuje mechanizm Sesji

Uwagi

Domyślnie ustawiona na true

Wyłącznie pozwala zaoszczędzić pamięć w przypadku bardzo obciążonego serwera

16

23

Dyrektywa page buffer

Format <%@ page buffer="sizekb" %>

<%@ page buffer="none" %>

WynikOkreśla rozmiar bufora wykorzystywanego przez zmienną out

UwagiBuforowanie umożliwia ustawienie nagłówków HTTP nawet jeśli pewna część strony została już wygenerowana (dopuki buffor nie został zapełniony lub celowo opróżniony)

Serwer może zastosować większy buffor niż zdefiniowano (nie mniejszy)

24

Dyrektywa page errorPageFormat<%@ page errorPage=”Wględny adres URL" %>

WynikOkreśla stronę JSP przeznaczonej do obsługi wyjątku wygenerowanego leczni nie przechwyconego przez bierzącą stronę.

UwagiWygenerowany wyjątek jest dosteępny automatycznie dla docelowej strony JSP prze zmienną exception

Plik konfiguracyjny web.xml pozwala na zdefniowanie wielu stron do obsługi konkretnych wyjątków bądź błędów HTTP

25

Dyrektywa page isErrorPage

Format<%@ page isErrorPage="true" %>

<%@ page isErrorPage="false" %> <%-- Default --%>

Wynik Określa że bierząca strona bezie stroną przeznaczoną do obsługi błędów generowanych przez inną stronę JSP

UwagiTworzona jest dodatkowo zmienna o nazwie exception

Należy przechwytywać jak najwięcej wyjątków mechanizm stron do obsługi błędów stosować w sytuacjach wyjątkowych

26

Dyrektywa page extends

Format <%@ page extends="package.class" %>

WynikOkreśla klasę bazową dla wygenerowanego na podstawie strony JSP servletu

UwagiStosować rozważnie

Typowe zastosowanie to wykorzystanie klas dostarczonych przez producenta serwera, na którym uruchamiana jest aplikacja (np.. Identyfikacja użytkownika itp.)

27

Inne dyrektywyFormat

<%@ page isThreadSafe="true" %> <%-- Default --%>

<%@ page isThreadSafe="false" %>

Wynik

Informacja dla systemu, że kod nie jest bezpieczny (threadsafe), więc sysem powinien wyłączyć wspólny dostęp do zasobów dla innych wątków

Zazwyczaj oznacza to że servlet impelmentuje SingleThreadModel

• Uwagi

Unikać, Powoduje degradację wydajności

Format

<%@ page isELIgnored="false" %>

<%@ page isELIgnored="true" %>

Wynik

Włącza bądź wyłącza JSP 2.0 Expression Language

28

29

• JSP Expressions

– Format: <%= expression %>

– Wrapped in out.print and inserted into _jspService

• JSP Scriptlets

– Format: <% code %>

– Inserted verbatim into the servlet’s _jspService method

• JSP Declarations

– Format: <%! code %>

–Inserted verbatim into the body of the servlet class

• Predefined variables

– request, response, out, session, application

• Limit the Java code that is directly in page

– Use helper classes, beans, servlet/JSP combo (MVC),

JSP expression language, custom tags

• XML Syntax

– There is alternative JSP syntax that is sometimes useful when

generating XML-compliant documents.

• But is more trouble than it is worth for most HTML applications

top related