Сервлеты, компоненты приложений Java 2 Platform Enterprise Edition. (Лекция 17)

Содержание

Слайд 2

СЕРВЛЕТЫ Сервлеты – компоненты приложений Java 2 Platform Enterprise Edition, выполняющиеся

СЕРВЛЕТЫ

Сервлеты – компоненты приложений Java 2 Platform Enterprise Edition, выполняющиеся

на стороне сервера, способные обрабатывать клиентские запросы и динамически генерировать ответы на них.
Наибольшее распространение получили сервлеты, обрабатывающие клиентские запросы по протоколу HTTP.
В настоящее время сервлеты поддерживаются большинством Web-серверов и являются частью платформы J2EE.
Слайд 3

Все сервлеты реализуют общий интерфейс Servlet. Для обработки HTTP-запросов можно воспользоваться

Все сервлеты реализуют общий интерфейс Servlet.
Для обработки HTTP-запросов можно воспользоваться

в качестве базового класса абстрактным классом HttpServlet.
Классы относящиеся к технологии сервлетов находятся в пакете javax.servlet.
Жизненный цикл сервлета начинается с его загрузки в память контейнером сервлетов при старте либо в ответ на первый запрос.
Далее происходят инициализация, обслуживание запросов и завершение существования.
Прежде всего вызывается конструктор сервлета(если он есть), а затем вызывается метод init().
Он дает сервлету возможность инициализировать данные и подготовиться для обработки запросов.
Данные задаются в файле web.xml в виде

имя_параметра
значение_парам

Слайд 4

После этого сервлет можно считать запущенным, он находится в ожидании запросов

После этого сервлет можно считать запущенным, он находится в ожидании запросов

от клиентов.
Появившийся запрос обслуживается методом service() сервлета, а все параметры запроса упаковываются в объект ServletRequest, который передается в качестве первого параметра методу service().
Второй параметр метода – объект ServletResponse.
В этот объект упаковываются выходные данные в процессе формирования ответа клиенту.
Каждый новый запрос приводит к новому вызову метода service().
Метод service() должен уметь обрабатывать сразу несколько запросов, т.е. быть синхронизирован для выполнения в многопоточных средах.
Если же нужно избежать множественных запросов, сервлет должен реализовать интерфейс SingleThreadModel, который не содержит ни одного метода и только указывает серверу об однопоточной природе сервлета.
Слайд 5

После завершения выполнения сервлета контейнер сервлетов вызывает метод destroy(), в теле

После завершения выполнения сервлета контейнер сервлетов вызывает метод destroy(), в теле

которого следует помещать код освобождения занятых сервлетом ресурсов.
Интерфейсом Servlet предусмотрена реализация еще двух методов: getServletConfig() и getServletInfo().
Первый возвращает объект типа ServletConfig, содержащий параметры конфигурации сервлета,
а второй – строку, описывающую назначение сервлета.
При разработке сервлетов в качестве базового класса в большинстве случаев используют не интерфейс Servlet, а класс HttpServlet, отвечающий за обработку запросов HTTP.
Слайд 6

Слайд 7

Класс HttpServlet имеет реализованный метод service(), служащий диспетчером для других методов,

Класс HttpServlet имеет реализованный метод service(), служащий диспетчером для других методов,

каждый из которых обрабатывает методы доступа к ресурсам.
В спецификации HTTP определены следующие методы: GET, HEAD, POST, PUT, DELETE, OPTIONS и TRACE.
Наиболее часто употребляются методы GET и POST, с помощью которых на сервер передаются запросы, а также параметры для их выполнения.
При использовании метода GET (по умолчанию) параметры передаются как часть URL, значения могут выбираться из полей формы или передаваться непосредственно через URL.
При этом запросы кэшируются и имеют ограничения на размер.
При использовании метода POST (method=POST) параметры (поля формы) передаются в содержимом HTTP-запроса и упакованы согласно полю заголовка Content-Type.
По умолчанию в формате: <имя>=<значение>&<имя>=<значение>&...
Слайд 8

В задачу метода service() класса HttpServlet входит анализ полученного через запрос

В задачу метода service() класса HttpServlet входит анализ полученного через запрос

метода доступа к ресурсам и вызов метода, имя которого сходно с названием метода доступа к ресурсам, но перед именем добавляется префикс do: doGet() или doPost().
Кроме этих методов могут использоваться методы: doHead(), doPut(), doDelete(), doOptions() и doTrace().
Очевидно, разработчик должен переопределить нужный метод, разместив в нем функциональную логику.
Слайд 9

Рассмотрим пример: import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import

Рассмотрим пример:
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MyServlet extends

HttpServlet {
public MyServlet() {
super();
...........................................................
}
public void init() throws ServletException {
.......................................................................................
}
Слайд 10

public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html");

public void doGet(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html");

PrintWriter out = response.getWriter();
out.print("This is ");
out.print(this.getClass().getName());
out.print(", using the GET method");}
public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.print("This is ");
out.print(this.getClass().getName());
out.print(", using the POST method");}
Слайд 11

public void destroy() { super.destroy(); .............................................................}} Интерфейсы ServletRequest и HttpServletRequest Поток

public void destroy() {
super.destroy();
.............................................................}}
Интерфейсы ServletRequest и HttpServletRequest
Поток данных поступает

от клиента в виде закодированного и упакованного запроса.
Вызывая методы интерфейса ServletRequest, можно получать определенный набор данных, посланных клиентом.
Метод getCharacterEncoding() определяет символьную кодировку запроса.
Методы getContentType() и getProtocol() – MIME-тип пришедшего запроса, а также название и версию протокола соответственно.
Слайд 12

Информацию об имени сервера, принявшего запрос, и порт, на котором запрос

Информацию об имени сервера, принявшего запрос, и порт, на котором запрос

был “услышан” сервером, выдают методы getServerName() и getServerPort().
Можно также узнать данные и о клиенте, от имени которого пришел запрос.
Его IP-адрес возвращается методом getRemoteAddr(), а его имя – методом getRemoteHost().
Если необходим прямой доступ к содержимому полученного запроса,то можно вызвать метод getInputStream() или getReader().
Первый возвращает ссылку на объект класса ServletInputStream, а второй – на BufferedReader.
После этого можно читать любой байт из полученного запроса, используя технику работы с потоками Java.
Слайд 13

Если, обращаясь к серверу, клиент помимо универсального адреса задал параметры сервлету

Если, обращаясь к серверу, клиент помимо универсального адреса задал параметры сервлету

то их можно узнать посредством следующих методов.
getParameter(String name) возвращает значение параметра по его имени или null, если параметра с таким именем нет.
getParameterValues(String name) возвращает массив строк, а именно все значения параметра по его имени, причем параметр может иметь несколько значений.
getParameterNames() возвращает объект типа Enumeration, позволяющий узнать имена всех присланных параметров.
Интерфейс HttpServletRequest является производным от интерфейса ServletRequest и используется для получения информации в HTTP-сервлетах.
Слайд 14

В интерфейсе HttpServletRequest имеются дополнительные методы: getCookies() возвращает массив cookies. getQueryString()

В интерфейсе HttpServletRequest имеются дополнительные методы:
getCookies() возвращает массив cookies.
getQueryString() возвращает строку

запроса HTTP
getRemoteUser() используется для получения имени пользователя, выполнившего запрос(если пользователь авторизировался или null) при использовании container-based authentication(устанавливается в настройках Tomcat в server.xml)
Рассмотрим пример:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class RequestClass extends HttpServlet {
public void doGet(HttpServletRequest req,
HttpServletResponse resp)
throws IOException, ServletException{
resp.setContentType("text/html");
PrintWriter out = resp.getWriter();
Слайд 15

out.println(" "); out.println(" Request Information "); out.println(" "); out.println(" Request Information

out.println("");
out.println("Request Information ");
out.println("");
out.println("

Request Information

");
out.println("
Method: "

+ req.getMethod());
out.println("
Request URI: " +
req.getRequestURI());
out.println("
Protocol: " + req.getProtocol());
out.println("
PathInfo: " + req.getPathInfo());
out.println("
Remote Address: " +
req.getRemoteAddr());
out.println("");
out.close();}}
Слайд 16

На экране получим: Request Information Method: GET Request URI: /FirstProject/RequestClass Protocol:

На экране получим:
Request Information
Method: GET
Request URI: /FirstProject/RequestClass
Protocol: HTTP/1.1
PathInfo: null
Remote Address: 127.0.0.1
Стоит

отметить метод req.getPathInfo().
Рассмотрим его работу. Пример:
String pathInfo = request.getPathInfo();
String pathTrans = request.getPathTranslated();
String uri = request.getRequestURI();
System.out.println("pathInfo: " + pathInfo);
System.out.println("pathTrans: " + pathTrans);
System.out.println("uri: " + uri);
Слайд 17

Тогда при запросе http://localhost:8080/blog/tag/java+mac+foo Получим на экране pathInfo: /java+mac+foo pathTrans: /Users/al/tomcat- 4.1.31/webapps/blog/tag/java+mac+foo uri: /blog/tag/java+mac+foo

Тогда при запросе
http://localhost:8080/blog/tag/java+mac+foo
Получим на экране
pathInfo: /java+mac+foo
pathTrans: /Users/al/tomcat-
4.1.31/webapps/blog/tag/java+mac+foo uri:

/blog/tag/java+mac+foo
Слайд 18

Интерфейсы ServletResponse и HttpServletResponse Генерируемые сервлетами данные передаются серверу-контейнеру с помощью

Интерфейсы ServletResponse и HttpServletResponse
Генерируемые сервлетами данные передаются серверу-контейнеру с помощью объектов,

реализующих интерфейс ServletResponse, а сервер, в свою очередь, пересылает ответ клиенту, инициировавшему запрос.
Слайд 19

В интерфейсе ServletResponse объявлены следующие методы: setContentType() задает MIME-тип генерируемых документов

В интерфейсе ServletResponse объявлены следующие методы:
setContentType() задает MIME-тип генерируемых документов
getOutputStream() возвращает

ссылку на поток ServletOutputStream.
getWriter() вернет ссылку на поток типа PrintWriter.
В интерфейсе HttpServletResponse, наследующем интерфейс ServletResponse, объявлены следующие методы:
addCookie() пересылает cookie на клиентскую станцию.
Слайд 20

sendError(int sc, String msg) сообщает о возникших ошибках в качестве параметра

sendError(int sc, String msg) сообщает о возникших ошибках в качестве параметра

передается код ошибки и при необходимости текстовое сообщение.
setDateHeader() добавляет в заголовок сообщения параметры.
setAttribute(String name, Object ob) метод устанавливает значения атрибутов компонентов, являющиеся внутренними параметрами для передачи информации между компонентами приложения, например от сервлета к странице JSP или другому сервлету.
Слайд 21

Рассмотрим пример: import java.io.*; import java.util.*; import javax.servlet.*; import javax.servlet.http.*; public

Рассмотрим пример:
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class RequestHeader extends HttpServlet {

public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws IOException, ServletException{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
Enumeration e = request.getHeaderNames();
while (e.hasMoreElements()){
String name = (String)e.nextElement();
String value = request.getHeader(name);
out.println(name + " = " + value);
}
}
}
Слайд 22

Html файл будет иметь вид: index.html ЗАПУСК СЕРВЛЕТА В браузере получим

Html файл будет иметь вид:

index.html

ЗАПУСК СЕРВЛЕТА



value="Execute">

В браузере получим
accept = image/gif, image/x-xbitmap, image/jpeg, image/pjpeg,
application/vnd.ms-excel, application/vnd.ms-powerpoint,
application/msword, application/x-shockwave-flash, */*
referer = http://localhost:8080/FirstProject/index.html
accept-language = en-us
content-type = application/x-www-form-urlencoded
accept-encoding = gzip, deflate
user-agent = Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)
host = localhost:8080
content-length = 0
connection = Keep-Alive
cache-control = no-cache
Слайд 23

Интерфейс ServletConfig Интерфейс ServletConfig имеет следующие методы: getServletName() позволяет получить имя

Интерфейс ServletConfig
Интерфейс ServletConfig имеет следующие методы:
getServletName() позволяет получить имя сервлета.
getInitParameterNames() метод

возвращает имена параметров инициализации в виде Enumeration.
getInitParameter(String n) позволяет получить значение конкретного параметра.
getServletContext() возвращает ссылку на ServletContext, используя которую можно узнать практически всю информацию о среде, в которой запущен и выполняется сервлет.
Слайд 24

Пример простого сервлета. import java.io.*; import java.util.Locale; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;

Пример простого сервлета.
import java.io.*;
import java.util.Locale;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(
urlPatterns={"/FirstServlettest"}
initParams={

@WebInitParam(name=“name1” value=“value1”)
@WebInitParam(name=“name1” value=“value2”)
} ) //Можно вместо аннотаций использовать XML файл wb.xml. Если присуствует и web.xml и аннотации, то xml имеет приоритет
public class FirstServlet extends HttpServlet {
private volatile int count;
public void init() throws ServletException {
super.init();
count = 0;
ServletConfig sc=this.getServletConfig();
Enumeration e=sc.getParameterNames()
while(e.hasMoreElements()){
String name=(String)e.nextElement();
String value=sc.getInitParameter(name);
} }
Слайд 25

public void doGet( HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {

public void doGet( HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {

performTask(req, res);
}
public void doPost( HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException{
performTask(req, res);
}
public void performTask(HttpServletRequest req,
HttpServletResponse res) throws ServletException, IOException {
String title = "First Servlet";
PrintWriter out = res.getWriter();
res.setContentType("text/html; charset=Cp1251");
out.println(""+ title + ""
+ "

This page is generated "
+ "by FirstServlet

This is its "+ ++count+ "
execution

");
out.close();
}
}
Слайд 26

Рассмотрим развертывание сервлета на сервере Tomcat. В каталоге, где установлен Web

Рассмотрим развертывание сервлета на сервере Tomcat.
В каталоге, где установлен Web сервер

будут следующие подкаталоги:
/bin – содержит startup, shutdown и другие исполняемые файлы;
/conf – содержит конфигурационные файлы, в частности конфигурационный файл контейнера сервлетов server.xml;
/server – помещаются классы;
/logs – помещаются log-файлы;
/webapps – в этот каталог помещаются папки, содержащие сервлеты и другие компоненты приложения
Слайд 27

В каталог /webapps необходимо поместить папку /FirstProject. Папка /FirstProject должна содержать

В каталог /webapps необходимо поместить папку /FirstProject.
Папка /FirstProject должна содержать

каталог /WEB-INF, в котором помещаются подкаталоги:
/classes – содержит класс сервлета FirstServlet.class;
/lib – содержит библиотеки классов (если они есть), упакованные в JAR-файлы (архивы java);
/src – содержит исходный файл сервлета FirstServlet.java;
а также web.xml – конфигурационный файл приложения.
Слайд 28

В файле web.xml необходимо прописать имя и путь к сервлету. Например:

В файле web.xml необходимо прописать имя и путь к сервлету. Например:


FirstServletname
FirstServletdisplay
test.com.FirstServlet




FirstServletname
/FirstServlettest


Вызвать сервлет можно набрав в браузере
http://localhost:8080/FirstProject/FirstServlettest
Стоит отметить, что - используется различными утилитами.
Слайд 29

Извлечение информации из запроса Пусть имеется следующая форма: Name : Credit:

Извлечение информации из запроса
Пусть имеется следующая форма:


Name

:



Credit:

Price:

Adress:





Для обработки данных, полученных из полей формы, используется сервлет:
Слайд 30

package test.com; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import

package test.com;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class FormRequest extends

HttpServlet {
public void doGet(HttpServletRequest req,
HttpServletResponse resp)
throws ServletException, IOException{
performTask(req, resp);
}
Слайд 31

public void performTask(HttpServletRequest req, HttpServletResponse resp) { try { String val[]

public void performTask(HttpServletRequest req,
HttpServletResponse resp) {
try {
String val[]

= new String[3];
int rest;
for (int i = 0; i < val.length; i++)
val[i] = req.getParameter("p" + i);
int c = Integer.valueOf(val[1]).intValue();
int p = Integer.valueOf(val[2]).intValue();
rest = c - p;
PrintWriter out = resp.getWriter();
resp.setContentType("text/html; charset=Cp1251");
out.println("");
out.println("FormRequest");
out.println("
");
out.println("");
Слайд 32

for (int i = 0; i out.println(" " + val[i] +

for (int i = 0; i < val.length; i++)
out.println("

");
out.println("");
out.println("Adress:" +req.getParameter("Adress"));
out.println("
");
out.println("Name
CreditPrice
Rest ");
out.println("
"
+ val[i] + "
" + rest + "
");
out.close();}
catch (Throwable e) {
e.printStackTrace();
}
}
}
Слайд 33

Cookie Рассмотрим сервлет, который задает куки, а затем считывает их из

Cookie
Рассмотрим сервлет, который задает куки, а затем считывает их из браузера.
import

java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.*;
import javax.servlet.http.*;
public class FormRequest extends HttpServlet {
public void doGet(HttpServletRequest req,
HttpServletResponse resp)
throws ServletException, IOException{
performTask(req, resp);
}
Слайд 34

public void performTask(HttpServletRequest req, HttpServletResponse resp) { try { String name=req.getParameter("p0");

public void performTask(HttpServletRequest req,
HttpServletResponse resp) {
try {
String name=req.getParameter("p0");

String val="";
//принимаем куки
Cookie cookie[]=req.getCookies();
PrintWriter out = resp.getWriter();
resp.setContentType("text/html;charset=Cp1251");
if((name==null)&&(cookie!=null)) {
if(cookie[0].getName().equals("Hello")){
val=cookie[0].getValue();
}
Слайд 35

out.println(" "); out.println(" FormRequest "); out.println(" "+"Hello "+val); out.println(" "); }

out.println("");
out.println("FormRequest");
out.println(""+"Hello "+val);
out.println(""); }
if(name!=null) {
out.println("");

out.println("FormRequest");
out.println(""+"Hello "+name);
out.println("");
//Создаем куки и отсылаем их браузеру
Cookie cook=new Cookie("Hello",name);
resp.addCookie(cook); }
Слайд 36

if((name==null)&&(cookie==null)){ out.println(" "); out.println(" "); out.println(" value=\" \"> "); out.println(" ");

if((name==null)&&(cookie==null)){
out.println(" ");
out.println("

");
out.println("

value=\" \">
");
out.println(" ");
out.println("");
}
out.close();
}
catch (Throwable e) {
e.printStackTrace();
}
}
}
Слайд 37

Методы класса Cookie: String getComment() Возвращает строку, описывающую назначение cookie (null,

Методы класса Cookie:
String getComment() Возвращает строку, описывающую назначение cookie (null, если

не было установлено каких-либо комментариев с помощью метода setCommerit).
String getDomain() Возвращает строку,содержащую имя домена cookie.
Тем самым определяется, какие серверы могут получить cookie.
По умолчанию cookie посылаются серверу, который отправил cookie клиенту.
Слайд 38

int getMaxAge() Возвращает целое число, представляющее максимальный возраст cookie в секундах.

 int getMaxAge() Возвращает целое число, представляющее максимальный возраст cookie в секундах.
String

getName() Возвращает строку, содержащую имя cookie, как оно было установлено конструктором.
String getPath() Возвращает строку, содержащую префикс URL для cookie.
Cookie могут быть «нацелены» на определенные URL, которые включают, каталоги Web-cepвера.
По умолчанию cookie возвращается сервисам, работающим в том же каталоге, что и сервис, который отправил cookie, или в подкаталоге этого каталога.
Слайд 39

boolean getSecure() Возвращает булево значение, указывающее, должен ли cookie передаваться с

 boolean getSecure() Возвращает булево значение, указывающее, должен ли cookie передаваться с

использованием протокола, обеспечивающего безопасность (true)
String getValue() Возвращает строку, содержащую значение cookie, как оно было установлено методом setValue или конструктором.
 int getVersion() Возвращает целое число, содержащее номер версии протокола cookies, используемого для создания cookie.
Значение, равное 0 (по умолчанию), указывает на изначальный протокол cookies, определенный Netscape.
Значение, равное 1, указывает на текущую версию, основанную на документе RFC 2109.
Слайд 40

void setComment(String purpose) Комментарий, описывающий назначение cookie, которое, предоставляется пользователю браузером.

void setComment(String purpose) Комментарий, описывающий назначение cookie, которое, предоставляется пользователю браузером. (Некоторые

браузеры дают возможность пользователю принимать каждый cookie индивидуально)
void setDomain(String pattern) Определяет, какие серверы могут получать cookie.
По умолчанию cookie отправляются серверу, который послал cookie клиенту.
Домен задается в виде “aaa.com”, что указывает на возможность получения этого cookie всеми серверами, имена доменов которых оканчиваются на aaa.com
void setMaxAge(int expiry) устанавливает максимальный возраст cookie в секундах.
Слайд 41

void setPath(String uri) Устанавливает префикс «целевого» URL, указывающий каталоги на сервере,

void setPath(String uri) Устанавливает префикс «целевого» URL, указывающий каталоги на сервере, которые

соответствуют сервисам, способным принимать этот cookie.
 void setSecure(boolean flag) значение true указывает, что cookie должен посылаться только с использованием протокола, обеспечивающего безопасность.
 void setValue(String newValue) задает значение cookie.
 void setVersion(int v) Задает протокол cookies для этого cookie.
Слайд 42

Session Когда пользователь делает запрос на сервер, сервер создает временную сессию

Session
Когда пользователь делает запрос на сервер, сервер создает временную сессию для

идентификации пользователя.
Когда тот же пользователь переходит на другую страницу сайта, сервер теперь может его идентифицировать.
Сессия - это временное уникальное соединение между сервером и пользователем и используется для идентификации пользователя среди других запросов или посещений на других страницах сайтов. 
Слайд 43

Для организации сессий используется класс HttpSession. Объект HttpSession может быть создан

Для организации сессий используется класс HttpSession.
Объект HttpSession может быть создан

с помощью метода getSession(boolean par), класса HttpServletRequest.
Если par имеет значение true, то сервлет должен создать уникальный объект HttpSession для клиента.
Если параметр равен false, то метод getSession возвращает null, если объект HttpSession для клиента пока не существует.
Методы класса HttpSession:
Object getAttribute(String name) возвращает объект связанный с именем name в сессии.
Слайд 44

Enumeration getAttributeNames() возвращает имена всех объектов в данной сессии. void setAttribute(String

 Enumeration getAttributeNames() возвращает имена всех объектов в данной сессии.
 void setAttribute(String name, Object value)
привязывает

объект value с именем name к сессии
 void removeAttribute(String name) удаляет объект с именем name из сессии.
String getId(). Каждая сессия, созданная сервером, имеет уникальный id, ассоциированный с ней для идентификации сессии среди других сессий.
Метод возвращает такой id.
Слайд 45

long getCreationTime(). Возвращает long значение, определяющее дату и время создания данной

long getCreationTime(). Возвращает long значение, определяющее дату и время создания данной

сессии.
long getLastTimeAccess(). Возвращает значение long, обозначающее последний визит на сайте.
 boolean isNew(). Возвращает boolean, определяя новая ли сессия.
void invalidate(). Аннулирует сессию.
Этот метод можно использовать на странице 'logout', позволяя пользователю закончить сессию. Если после этого пользователь снова зайдет на сайт - создастся новая сессия под него.
 Object getValue(String name) то же, что и getAttribute
 void putValue(String name, Object value) то же, что и setAttribute.
Слайд 46

Рассмотрим пример: import java.io.*; import javax.servlet.*; import javax.servlet.http.*; import java.util.*; public

Рассмотрим пример:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class BookStoreServlet extends HttpServlet {

public void doGet (HttpServletRequest req,
HttpServletResponse res)
throws ServletException, IOException{
res.setContentType("text/html");
PrintWriter out = res.getWriter();
Слайд 47

out.println(" out.println(" "); out.println(" "); out.println(" Welcome to WholeLottaBooks.com! "); out.println("Would

out.println(" out.println("");
out.println("

");
out.println("

Welcome to
WholeLottaBooks.com!

");
out.println("Would you like to

begin shopping?");
out.println("
");
out.println("");
out.println("
");
out.println("");
out.println("");
out.println("");}
Слайд 48

public void doPost (HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException{ res.setContentType("text/html");

public void doPost (HttpServletRequest req,
HttpServletResponse res)
throws ServletException, IOException{
res.setContentType("text/html");
PrintWriter

out = res.getWriter();
ShoppingCart sc;
HttpSession session = req.getSession(true);
Слайд 49

if (session.getValue("Cart") == null){ sc= new ShoppingCart(); session.putValue("Cart",sc); int acct =

if (session.getValue("Cart") == null){
sc= new ShoppingCart();
session.putValue("Cart",sc);
int acct = new Random().nextInt();
if (acct

< 0){acct = acct -1;}
((ShoppingCart)session.getValue("Cart"))
.setAccountNum(acct);
}
out.println("Your account number is " +
((ShoppingCart)session.getValue("Cart"))
.getAccountNum());
}
}
Слайд 50

Класс ShoppingCart имеет вид: import java.util.*; import java.io.Serializable; public class ShoppingCart

Класс ShoppingCart имеет вид:
import java.util.*;
import java.io.Serializable;
public class ShoppingCart implements Serializable

{
private int accountNum;
private Vector Items;
public ShoppingCart(){ Items = new Vector();}
public int getAccountNum(){
return this.accountNum;
}
public void setAccountNum(int accountNum){
this.accountNum = accountNum;
}
Слайд 51

public Iterator getItems(){return this.Items.iterator(); } public boolean addItem(int item){ return Items.add(new

public Iterator getItems(){return this.Items.iterator(); }
public boolean addItem(int item){
return Items.add(new Integer(item));\

}
public String toString(){
return "ShoppingCart for " + accountNum;
}
}
Слайд 52

Фильтры Сервлетный фильтр, в соответствии со спецификацией, это Java-код, пригодный для

Фильтры

Сервлетный фильтр, в соответствии со спецификацией, это Java-код, пригодный для повторного

использования и позволяющий преобразовать содержание HTTP-запросов, HTTP-ответов и информацию, содержащуюся в заголовках HTML.
Сервлетный фильтр занимается предварительной обработкой запроса, прежде чем тот попадает в сервлет, и/или последующей обработкой ответа, исходящего из сервлета.
Слайд 53

Сервлетные фильтры могут: перехватывать инициацию сервлета прежде, чем сервлет будет инициирован;

Сервлетные фильтры могут:
перехватывать инициацию сервлета прежде, чем сервлет будет инициирован;
определить

содержание запроса прежде, чем сервлет будет инициирован;
модифицировать заголовки и данные запроса, в которые упаковывается поступающий запрос;
перехватывать инициацию сервлета после обращения к сервлету.
Слайд 54

Сервлетный фильтр может быть конфигурирован так, что он будет работать с

Сервлетный фильтр может быть конфигурирован так, что он будет работать с

одним сервлетом или группой сервлетов.
Основой для формирования фильтров служит интерфейс javax.servlet.Filter, который реализует три метода:
void init (FilterConfig config) throws
ServletException;
void destroy ();
void doFilter (ServletRequest request,
ServletResponse response,
FilterChain chain)
throws IOException, ServletException;
Слайд 55

Метод init вызывается прежде, чем фильтр начинает работать, и настраивает конфигурационный

Метод init вызывается прежде, чем фильтр начинает работать, и настраивает конфигурационный

объект фильтра.
Метод doFilter выполняет непосредственно работу фильтра.
Таким образом, сервер вызывает init один раз, чтобы запустить фильтр в работу, а затем вызывает doFilter столько раз, сколько запросов будет сделано непосредственно к данному фильтру.
После того, как фильтр заканчивает свою работу, вызывается метод destroy.
Слайд 56

Таким образом, фильтр имеет следующий вид: import java.io.*; import javax.servlet.*; import

Таким образом, фильтр имеет следующий вид:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*; 
@WebFilter( urlPatterns={“/*”}
initParams={@WebInitParam(name=“active”

value=“true”)}
) //Эти параметры также можно задавать и в файле web.xml
public class FilterConnect implements Filter{ 
private FilterConfig config = null; 
private boolean active =false; 
public void init (FilterConfig config) throws
ServletException {  
this.config = config;  
String act = config.getInitParameter("active");  
if (act != null){
   active = (act.toUpperCase().equals("TRUE")); 
}
Слайд 57

public void doFilter (ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,

public void doFilter (ServletRequest request,
ServletResponse response, 
FilterChain chain)
throws

IOException, ServletException {  
if (active){
…………………………..
}  
chain.doFilter(request, response); 
}
 public void destroy() {  
config = null; } 
}
Слайд 58

Интерфейс FilterConfig содержит метод для получения имени фильтра, его параметров инициализации

Интерфейс FilterConfig содержит метод для получения имени фильтра, его параметров инициализации

и контекста активного в данный момент сервлета.
С помощью метода doFilter каждый фильтр получает текущий запрос request и ответ response, а также FilterChain, содержащий список фильтров, предназначенных для обработки.
В doFilter фильтр может делать с запросом и ответом всё, что необходимо.
Затем фильтр вызывает chain.doFilter, чтобы передать управление следующему фильтру.
Слайд 59

После возвращения этого вызова фильтр может по окончании работы своего метода

После возвращения этого вызова фильтр может по окончании работы своего метода

doFilter выполнить дополнительную работу над полученным ответом.
После того, как класс-фильтр откомпилирован, его необходимо установить в контейнер и "приписать"(map) к одному или нескольким сервлетам.
Например:
Слайд 60

FilterName FilterConnect active true FilterName ServletName


FilterName
FilterConnect

active
true


<-- Подключение фильтра к сервлету

-->

FilterName
ServletName

Слайд 61

В представленном коде дескриптора поставки web.xml объявлен класс-фильтр FilterConnect с именем

В представленном коде дескриптора поставки web.xml объявлен класс-фильтр FilterConnect с именем

FilterName.
Фильтр имеет параметр инициализации active, которому присваивается значение true.
Фильтр FilterName в разделе подключен к сервлету ServletName.
Порядок, в котором контейнер строит цепочку фильтров для запроса определяется следующими правилами:
Слайд 62

цепочка, выстраивается в том порядке, в котором встречаются соответствующие описания фильтров

цепочка, выстраивается в том порядке, в котором встречаются соответствующие описания фильтров

в web.xml;
Для связи фильтра со страницами HTML или группой сервлетов необходимо использовать тег .
Например:
Слайд 63

FilterName *.html фильтр будет применен ко всем вызовам страниц HTML. Рассмотрим


FilterName
*.html

фильтр будет применен ко всем вызовам страниц HTML.
Рассмотрим

пример использования фильтра.
Рассмотрим задачу нахождения минимального и максимального элемента массива.
Слайд 64

Фильтр MaxFilter находит максимальный элемент массива: public class MaxFilter implements Filter{

Фильтр MaxFilter находит максимальный элемент массива:
public class MaxFilter implements Filter{
private

FilterConfig config = null;
private boolean active = false;
public void init (FilterConfig config) throws
ServletException {
this.config = config;
String act = config.getInitParameter("active");
if (act != null){
active = (act.toUpperCase().equals("TRUE"));}
}
Слайд 65

public void doFilter (ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,

public void doFilter (ServletRequest request, ServletResponse response,
FilterChain chain) throws

IOException, ServletException{
if (active){
String param=request.getParameter("ArrayName");
String[] mass=param.split(" ");
int mas[]=new int[mass.length];
int i=0;
for(String s: mass){
mas[i]=Integer.parseInt(s);
i++; }
int max=mas[0];
for(int j=1; j if(max max=mas[j]; }
}
request.setAttribute("maxValue", new Integer(max));
}
chain.doFilter(request, response);
}
Слайд 66

public void destroy(){ config = null; } } Фильтр MinFilter находит

public void destroy(){
config = null;
}
}
Фильтр MinFilter находит минимальный элемент

массива. Вызывается после фильтра MaxFilter.
public class MinFilter implements Filter{
private FilterConfig config = null;
private boolean active = false;
………………………………………………
Слайд 67

public void init (FilterConfig config) throws ServletException{ ………………} public void destroy(){

public void init (FilterConfig config) throws ServletException{ ………………}
public void

destroy(){
config = null;
}
public void doFilter (ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
if (active){
//Данная строка нужна, чтобы убедиться, что первым был вызван фильтр MaxFilter
Integer value=(Integer)request.getAttribute("maxValue");
if(value!=null){
String param=request.getParameter("ArrayName");
String[] mass=param.split(" ");
int mas[]=new int[mass.length];
int i=0;
for(String s: mass){
mas[i]=Integer.parseInt(s);
i++;
}
Слайд 68

int min=mas[0]; for(int j=1; j if(min>mas[j]){ min=mas[j]; } } request.setAttribute("minValue", new

int min=mas[0];
for(int j=1; j if(min>mas[j]){
min=mas[j]; }
}
request.setAttribute("minValue",

new Integer(min));
}
}
chain.doFilter(request, response);
}
}
Тогда сервлет обслуживающий запросы имеет вид:
public class ActionServlet extends HttpServlet {
protected void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
Слайд 69

protected void processRequest( HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

protected void processRequest(
HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {

response.setContentType("text/html;charset=UTF-8");
Integer
value=(Integer)request.getAttribute("maxValue");
Integer
value1=(Integer)request.getAttribute("minValue");
int maxValue=value.intValue();
int minValue=value1.intValue();
PrintWriter out = response.getWriter();
Слайд 70

try { out.println(" "); out.println(" "); out.println(" Servlet ActionServlet "); out.println("

try {
out.println("");
out.println("");
out.println("Servlet ActionServlet");
out.println("");
out.println("");
out.println("

The

max value is " + maxValue +"");
out.println("

The min value is " + minValue +"

");
out.println("");
out.println("");
} finally {
out.close();
}
}
}
Слайд 71

Соответственно форма имеет вид: maxlength="15" value=""> Файл web.xml в данном случае имеет вид: MyServlet ActionServlet

Соответственно форма имеет вид:


maxlength="15"

value="">


Файл web.xml в данном случае имеет вид:

MyServlet
ActionServlet

Слайд 72

MaxFilter MaxFilter active true MinFilter MinFilter active true


MaxFilter
MaxFilter

active
true



MinFilter
MinFilter

active

true


Слайд 73

MyServlet /MyServlet MaxFilter MyServlet MinFilter MyServlet


MyServlet
/MyServlet


MaxFilter
MyServlet


MinFilter
MyServlet

Слайд 74

Класс RequestDispatcher В некоторых случаях необходимо обратиться к другому сервлету, странице

Класс RequestDispatcher
В некоторых случаях необходимо обратиться к другому сервлету, странице

JSP, документу HTML, XML или другому ресурсу.
Если требуемый ресурс находится в том же контексте, что и сервлет, который его вызывает, то для получения ресурса необходимо использовать метод
public RequestDispatcher
getRequestDispatcher(String path);
представленному в интерфейсе ServletRequest.
Здесь path - это путь к ресурсу относительно контекста.
Например, необходимо обратиться к сервлету Connect:
RequestDispatcher rd =
request.getRequestDispatcher("Connect");
Слайд 75

Если ресурс находится в другом контексте, то необходимо предварительно получить контекст

Если ресурс находится в другом контексте, то необходимо предварительно получить контекст

методом
public ServletContext getContext(
String uripath);
интерфейса ServletContext, а потом использовать метод
public RequestDispatcher
getRequestDispatcher(String uripath);
интерфейса ServletContext.
Здесь путь uripath должен быть абсолютным, т.е. начинаться с наклонной черты /.
Слайд 76

Например: RequestDispatcher rd = config.getServletContext() .getContext("/prod").getRequestDispatcher( "/prod/Customer"); Если требуемый ресурс -

Например:
RequestDispatcher rd =
config.getServletContext()
.getContext("/prod").getRequestDispatcher(
"/prod/Customer");
Если требуемый ресурс - сервлет,

помещенный в контекст под своим именем, то для его получения можно обратиться к методу
RequestDispatcher getNamedDispatcher (
String name);
интерфейса ServletContext.
Слайд 77

Все три метода возвращают null, если ресурс недоступен или сервер не

Все три метода возвращают null, если ресурс недоступен или сервер не

реализует интерфейс RequestDispatcher.
Как видно из описания методов, к другим ресурсам можно обратиться только через объект типа RequestDispatcher, который предлагает два метода обращения к ресурсу. Первый метод
public void forward (ServletRequest request,
ServletResponse response);
просто передает управление другому ресурсу, предоставив ему свои аргументы request и response.
Слайд 78

Вызывающий сервлет выполняет предварительную обработку объектов request и response и передает

Вызывающий сервлет выполняет предварительную обработку объектов request и response и передает

их вызванному сервлету или другому ресурсу, который окончательно формирует ответ response и отправляет его клиенту или, опять-таки, вызывает другой ресурс.
Например:
if (rd != null) {
rd.forward (request, response);}
else {
response.sendError(
HttpServletResponse.SC_NO_CONTENT);
}
Слайд 79

Вызывающий сервлет не должен выполнять какую-либо отправку клиенту до обращения к

Вызывающий сервлет не должен выполнять какую-либо отправку клиенту до обращения к

методу forward, иначе будет выброшено исключение класса IllegalStateException.
Если же вызывающий сервлет уже что-то отправлял клиенту, то следует обратиться ко второму методу
public void include (ServletRequest request,
ServletResponse response);
Этот метод вызывает ресурс, который на основании объекта request может изменить тело объекта response.
Но вызванный ресурс не может изменить заголовки и код ответа объекта response.
Это естественное ограничение, поскольку вызывающий сервлет мог уже отправить заголовки клиенту.
Попытка вызванного ресурса изменить заголовок будет просто проигнорирована
Слайд 80

Рассмотрим пример: ………………………………………………………… request.getSession().setAttribute("model", model); RequestDispatcher dispatcher = getServletContext() .getRequestDispatcher("/form.jspx"); try

Рассмотрим пример:
…………………………………………………………
request.getSession().setAttribute("model", model);
RequestDispatcher dispatcher = getServletContext()
.getRequestDispatcher("/form.jspx");
try {
dispatcher.forward(request, response);
} catch

(ServletException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
Слайд 81

При этом form.jspx имеет вид: xmlns:c="http://java.sun.com/jsp/jstl/core" version="2.0"> pageEncoding="UTF-8"/> EN Значение:

При этом form.jspx имеет вид:
xmlns:c="http://java.sun.com/jsp/jstl/core" version="2.0">
pageEncoding="UTF-8"/>

name="text">
EN

Значение:




Слайд 82

Обработка событий Существует несколько интерфейсов, которые позволяют следить за событиями, связанными

Обработка событий
Существует несколько интерфейсов, которые позволяют следить за событиями, связанными с

сеансом, контекстом и запросом сервлета, генерируемыми во время жизненного цикла Web-приложения:
javax.servlet.ServletContextListener – обрабатывает события создания/удаления контекста сервлета;
javax.servlet.http.HttpSessionListener – обрабатывает события создания/удаления HTTP-сессии;
Слайд 83

javax.servlet.ServletContextAttributeListener – обрабатывает события создания/удаления/модификации атрибутов контекста сервлета; javax.servlet.http.HttpSessionAttributeListener – обрабатывает

javax.servlet.ServletContextAttributeListener – обрабатывает события создания/удаления/модификации атрибутов контекста сервлета;
javax.servlet.http.HttpSessionAttributeListener – обрабатывает события

создания/удаления/модификации атрибутов HTTP-сессии;
javax.servlet.http.HttpSessionBindingListener – обраба­тывает события привязывания/разъединения объекта с атрибутом HTTP-сессии;
javax.servlet.http.HttpSessionActivationListener – обрабаты­вает события связанные с активацией/дезактивацией HTTP-сессии;
javax.servlet.ServletRequestListener – обрабатывает события создания/удаления запроса;
javax.servlet.ServletRequestAttributeListener – обрабаты­вает события создания/удаления/модификации атрибутов запроса сервлета.
Слайд 84

Методы соответствующих интерфейсов. ServletContextListener Этот Listener позволяет разработчику "словить" момент когда

Методы соответствующих интерфейсов.
ServletContextListener
Этот Listener позволяет разработчику "словить" момент когда ServletContext инициализируется

либо уничтожается.
Его можно использовать, например, для открытия соединения с базой данных в момент создания контекста и закрытия соединения в момент уничтожения контекста.
contextDestroyed(ServletContextEvent e)
contextInitialized(ServletContextEvent e)
Соответственно ServletContextEvent содержит метод
 ServletContext getServletContext(), который возвращает измененнный ServletContext.
Пример1.
Слайд 85

WebServlet( urlPatterns={"/Servlet1"} ) public class Sevlet1 extends HttpServlet { protected void

WebServlet( urlPatterns={"/Servlet1"} )
public class Sevlet1 extends HttpServlet {
protected void processRequest(HttpServletRequest

request,
HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
out.println("");
out.println("");
out.println("Servlet Sevlet1");
out.println("");
out.println("");
out.println("

Servlet Sevlet1 " +"

");
out.println("");
out.println("");
} finally { out.close(); }
}
}
Слайд 86

Обработчик события: @WebListener() //Зарегестрировать обработку событий можно также и в web.xml

Обработчик события:
@WebListener()
//Зарегестрировать обработку событий можно также и в web.xml
// ServletListener1


public class ServletListener1 implements ServletContextListener {
public void contextInitialized(ServletContextEvent sce) {
System.out.println("created");
}
public void contextDestroyed(ServletContextEvent sce) {
System.out.println("destroyed");
}
}
Теперь в консоли сервера при загрузке сервлета будет выведено created, а при выгрузке destroyed.
Слайд 87

HttpSessionListener Этот Listener позволяет разроботчику "словить" момент создания и уничтожения сессии.

HttpSessionListener
Этот Listener позволяет разроботчику "словить" момент создания и уничтожения сессии.
sessionCreated(HttpSessionEvent e)
sessionDestroyed(HttpSessionEvent

e)
Класс HttpSessionEvent имеет метод
HttpSession getSession() – возвращает сессию, которая была изменена.
Слайд 88

ServletContextAttributeListener Этот Listener используется для “прослушивания" событий, происходящих с атрибутами в

ServletContextAttributeListener
Этот Listener используется для “прослушивания" событий, происходящих с атрибутами в контексте

сервлета (ServletContext).
attributeAdded(ServletContextAttributeEvent e)
attributeRemoved(ServletContextAttributeEvent e)
attributeReplaced(ServletContextAttributeEvent e)
Вызывается когда атрибут меняет значение
Класс ServletContextAttributeEvent имеет два метода
String getName() - возвращает имя измененного атрибута
Object getValue() –возвращает значение атрибута, которое было удалено или добавлено.
Слайд 89

HttpSessionAttributeListener Этот Listener используется для "слушания" событий, происходящих с атрибутами в

HttpSessionAttributeListener
Этот Listener используется для "слушания" событий, происходящих с атрибутами в сервлет

контексте (ServletContext).
attributeAdded(HttpSessionBindingEvent e)
Вызывается когда атрибут добавляется в ServletContext
attributeRemoved(HttpSessionBindingEvent e)
Вызывается когда атрибут удаляется из ServletContext-a  attributeReplaced(HttpSessionBindingEvent e)
Вызывается когда атрибут меняет значение
Класс HttpSessionBindingEvent имеет два метода
String getName()- возвращает имя аттрибута под которым объект был привязан к сессии
HttpSession getSession() - возвращает имя сессии, к которой объект был привязан.
Слайд 90

HttpSessionBindingListener Этот Listener так-же используется для прослушивания событий происходящих с атрибутами

HttpSessionBindingListener
Этот Listener так-же используется для прослушивания событий происходящих с атрибутами в

сессии. Разница между HttpSessionAttributeListener и HttpSessionBindingListener HttpSessionAttributeListener: декларируется в web.xml, экземпляр класса создается автоматически (контейнером) в единственном числе  и применяется ко всем сессиям HttpSessionBindingListener: экземпляр этого класса должен быть создан и закреплён за определённой сессией программистом "вручную", количество экземпляров регулируется программистом.
valueBound(HttpSessionBindingEvent e)
Вызывается когда объект добавляется в сессию
valueUnbound(HttpSessionBindingEvent e)
Вызывается когда объект удаляется из сессии
Слайд 91

Рассмотрим пример. public class MyBindingListener implements HttpSessionBindingListener { public void valueBound(HttpSessionBindingEvent

Рассмотрим пример.
public class MyBindingListener implements
HttpSessionBindingListener {
public void valueBound(HttpSessionBindingEvent e){

System.out.println("Bound“ +e.getName());
}
public void valueUnbound(HttpSessionBindingEvent e){
System.out.println("UnBound“+ e.getName());
}
}
Сервлет имеет вид:
Слайд 92

public class Servlet1 extends HttpServlet { protected void processRequest(HttpServletRequest request, HttpServletResponse

public class Servlet1 extends HttpServlet {
protected void processRequest(HttpServletRequest request,
HttpServletResponse

response) throws ServletException, IOException {
try {
MyBindingListener mb=new MyBindingListener();
HttpSession hs=request.getSession();
hs.setAttribute("name", mb); // в этом месте в консоль сервера
будет выведено Bound name
hs.setAttribute("name", "bbb"); // в этом месте в консоль сервера
будет выведено UnBound name
} finally {
}
}
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
processRequest(request, response); }
}
Слайд 93

HttpSessionActivationListener Этот Listener используется атрибутами сессии в случае, если сессия будет

HttpSessionActivationListener
Этот Listener используется атрибутами сессии в случае, если сессия будет "мигрировать"

между различными JVM в распределённых приложениях.
Имеет следующие методы:
void sessionWillPassivate(HttpSessionEvent se) 
Вызывается перед тем, как сессия станет пассивной перед миграцией void sessionDidActivate(HttpSessionEvent se) Вызывается после того, как сессия   стала активной после миграции
Слайд 94

ServletRequestListener Этот Listener используется, соответственно, для того, чтоб "словить" момент создания

ServletRequestListener
Этот Listener используется, соответственно, для того, чтоб "словить" момент создания и

уничтожения запроса. 
void requestDestroyed(ServletRequestEvent se)
Вызывается когда запрос уничтожается  void requestInitialized(ServletRequestEvent se) Вызывается когда запрос инициализируется
ServletRequestEvent имеет два метода
ServletContex getServletContext() возвращает контекст сервлета для текущего приложения
ServletRequest getServletRequest() возвращает измененній запрос.