4.57M
Категория: ПрограммированиеПрограммирование

Что такое JSP?

1.

Что такое JSP?

2.

• JSP (JavaServer Pages) — платформеннонезависимая, переносимая и легко
расширяемая технология для разработки вебприложений, работающая на виртуальной
машине Java (JVM). JSP позволяет вебразработчикам создавать содержимое,
состоящее из статических исходных данных,
которые могут быть оформлены в одном из
текстовых форматов HTML, SVG, WML, или
XML, и JSP-элементов, которые конструируют
динамическое содержимое. Кроме этого могут
использоваться библиотеки JSP-тегов, а также
Expression Language (EL), для внедрения Javaкода в статичное содержимое JSP-страниц.

3.

Цели и задачи JSP

4.

• Правильное использование JSP позволяет
выполнить чистую реализацию паттерна
Model-View-Controller, позволяющую четко
отделить представление от бизнес-логики.
Эта технология также позволяет считывать,
повторно использовать и обслуживать
страницы, то есть, в принципе, мы имеем
что-то более читабельное, чем сервлет.

5.

• JSP позволяет использовать код для
разметки. Цель JSP-технологии состоит
в том, чтобы отделить контент от логики,
и позволить «не программистам» создавать
необходимые страницы, которые содержат
пользовательские теги. JSP относительно
просты в сборке и предоставляют полный
набор Java API.

6.

• Проблема в самом последнем примере
заключается в том, что это статический
HTML-документ. Возможно, так было-бы
проще писать, и, вероятно, будет
бесконечно легче поддерживать, чем
пример, написанный на Java, но здесь нет
ничего динамичного. JSP — это, по сути,
гибридное решение, сочетающее Java-код
и HTML-теги. JSP могут содержать любой
HTML-тег в дополнение к Java-коду,
встроенным JSP-тегам, пользовательским
JSP-тегам и тому, что называется языком
выражений (Expression Language).

7.

• Следующий пример, использует JSP вместо
сервлета для отображения цитаты из
известной поэмы.

8.

9.

• Этот пример почти идентичен
предыдущему HTMLпримеру. Единственное
отличие — первая строка. Это одна из
нескольких директив JSP, в этой директиве
задается тип содержимого и кодировка
символов на странице. То, что было можно
сделать с использованием методов
setContentType и setCharacterEncoding
HttpServletResponse. Все остальное в этом
JSP — это простой HTML, переданный
клиенту «как есть» в ответе.

10.

Создание первого JSP

11.

• После того как были изучены сервлеты.
Необходимо ответить на вопрос «Что
должно происходить в методе service?».
Метод service класса Servlet обслуживает
все входящие запросы. Он должен
анализировать и обрабатывать данные по
входящему запросу на основе
используемого протокола, а затем
возвращать ответ клиенту. Если метод
service возвращает ответ обратно в сокет
без данных, клиент, скорее всего, получит
сетевую ошибку, например «сброс
соединения».

12.

• В HTTP протоколе метод service должен
понимать заголовки и параметры, которые
клиент отправляет и затем возвращать
валидный HTTP-ответ, который включает
в себя минимальные заголовки HTTP, но
поскольку HttpServlet заботится обо всем
этом, методы doGet и doPost могут быть
буквально пустыми. Во время выполнения
JSP должно произойти много вещей, но все
эти «должны» обрабатываются за нас.

13.

• Чтобы продемонстрировать это, создадим
файл с именем blank.jsp в корневом
каталоге пустого проекта. Удалим все его
содержимое (IDE может поместить туда
какой-то код). Произведем redeploy нашего
проекта. После перехода
к http://localhost:8080/poem/blank.jsp, не
получим никаких ошибок. Все работает
нормально, мы просто получаем
бесполезную пустую страницу. Теперь
добавим в него следующий код,
произведем redeploy и перезагрузим
страницу:

14.

15.

• Сейчас существует только небольшая разница
между blank.jsp и index.jsp — отсутствующий
специальный тег, который находится в первой
строке index.jsp. И все же, контент все еще
отображается одинаково. Это связано с тем,
что JSP по умолчанию имеют тип содержимого
text/html и кодировку символов ISO-8859-1.
Однако, эта кодировка по умолчанию,
несовместима со многими специальными
символами, которые не содержатся
в английском языке, что может помешать
локализовать приложение.

16.

• Итак, как минимум, JSP должен содержать
HTML для отображения информации
пользователю. Тем не менее, чтобы
убедиться, что HTML отображается
правильно во всех браузерах во всех
системах на многих языках, необходимо
включить определенные теги JSP для
управления данными, отправленными
клиенту, такими как установка кодировки
UTF-8.

17.

• В JSP можно использовать несколько
различных типов тегов. Один из типов тегов
директивы Вы уже видели:
• Этот тег директивы предоставляет
некоторые элементы управления
передачей JSP клиенту, отображением
и обратной передачей. В примере index.jsp
директива page выглядит следующим
образом:

18.

• Атрибут language сообщает контейнеру,
какой JSPскриптовый язык используется для
этого JSP. Язык сценариев JSP (не путайте
с интерпретируемыми языками
сценариев) — это язык, который может
быть встроен в JSP для написания
определенных действий.

19.

• Технически, можно опустить этот атрибут.
Поскольку Java является единственным
поддерживаемым языком сценариев JSP,
и используется по умолчанию
в спецификации. Атрибут contentType
сообщает контейнеру значение заголовка
Content-Type, которое должно быть
отправлено обратно вместе с ответом.
Заголовок ContentType содержит как тип
содержимого, так и кодировку символов,
разделенных точкой с запятой. Если Вы
помните, в файле index_jsp.java,
содержится:

20.

• Следует отметить, что предыдущий
фрагмент кода является эквивалентом
следующих двух строк:
• И, более того, они эквивалентны
следующей строке кода:

21.

• Таким образом, нужно отметить, что
существует несколько способов
выполнения одной и той же задачи.
Методы setContentType
и setCharacterEncoding являются удобными.
Какой вариант использовать — зависит от
Вас. Как правило, необходимо выбрать
один и придерживаться его, чтобы
избежать путаницы. Однако, поскольку
большая часть кода будет основана на JSP,
в основном мы будем иметь дело только
с атрибутом contentType директивы page.

22.

Добавление import в JSP

23.

• Если в JSP Java-код использует класс
напрямую, необходимо либо ссылаться на
него, используя его полное имя класса,
либо включать директиву импорта в JSPфайл. И так же, как каждый класс в пакете
java.lang импортируется неявно в файлы
Java, каждый класс пакета java. lang неявно
импортируется в JSP-файлы. Для того чтобы
импортировать один или несколько классов
необходимо добавить атрибут импорта
в директиву страницы:

24.

• В этом примере используется запятая для
разделения нескольких импортов, и в
результате импортируется класс
java.io.IOException и все члены пакета
java.util. Не обязательно использовать
отдельную директиву для импорта классов,
можно комбинировать с другими
атрибутами:

25.

• Можно также использовать несколько
директив:

26.

• Каждый тег JSP, который ничего не выводит,
а также директивы, декларации
и сценарии, приводят к пустым строкам при
отображении клиенту. Таким образом, если
у Вас есть много директив, за которыми
следуют различные объявления
и сценарии, Вы можете получить десятки
пустых строк. Чтобы компенсировать это,
разработчики JSP часто связывают конец
одного тега с началом следующего:

27.

• Этот пример кода дает тот же результат, что
и предыдущий, но в результате он выводит
только одну пустую строку вместо трех.

28.

Понятие директива, объявление,
сценарий и выражение

29.

• Кроме различных тегов HTML и JSP, которые
можно использовать в JSP, существует также
несколько уникальных структур, которые
определяют своего рода JSP-язык. Это
директивы, объявления, сценарии
и выражения.

30.

• Директивы используются, для того чтобы
указать интерпретатору JSP, какое действие
он должен выполнить (например,
установить тип содержимого) или сделать
предположение о файле (например, какой
язык скриптинга он использует),
импортировать класс, включить другой JSP
во время преобразования или включения
библиотеки тегов JSP.

31.

• Объявления используются для того чтобы
определить что-то в рамках класса JSP
Servlet. Например, переменные
экземпляра, методы или классы в теге
объявления. Необходимо также помнить,
что все классы, которые определяются, на
самом деле являются внутренними
классами класса JSP Servlet, так как все они
объявлены в созданном классе JSP Servlet.

32.

• Сценарий, так же как и объявление, содержит
Java-код. Тем не менее, сценарии имеют
разную область видимости. Код в объявлении
копируется в тело класса JSP Servlet во время
преобразования и поэтому должен
использоваться для объявления какого-то поля
или метода, сценарии же копируются в тело
метода _jspService. Любые локальные
переменные, которые находятся в области
действия этого метода, будут находиться
в пределах области сценариев, и любой код,
который видимый в пределах тела метода,
является видимым в сценарии.

33.

• Таким образом, можно определить локальные
переменные, но не поля экземпляров. Можно
использовать условные операторы,
манипулировать объектами и выполнять
арифметику, все, что невозможно сделать
в объявлении. Можно даже определить
классы, но классы не будут иметь области
видимости вне метода _jspService. Класс,
метод или переменная, определенные
в объявлении, могут использоваться
в сценарии, но класс или переменная,
определенные в сценарии, не могут
использоваться в объявлении.

34.

• Выражения содержат простой Java-код,
который чтото возвращает клиенту.
Например, арифметический расчет внутри
выражения, в результате которого будет
возвращено и отображено числовое
значение. По существу, любой код, который
может находиться справа от оператора
присваивания, может быть помещен
в выражение. Выражения выполняются
в рамках того же метода, что и сценарии, то
есть выражения будут скопированы в метод
_jspService.

35.

• В качестве примера рассмотрим
следующий код, который содержит
директивы, объявления, сценарии
и выражения.

36.

37.

38.

• Для того чтобы собрать проект, необходимо
создать JSP-файл с именем example.jsp
в корневом каталоге пустого проекта,
и поместить в него код из предыдущего
примера. Затем, нужно скомпилировать
и запустить приложение, перейти по адресу
http://localhost:8080/ poem/example.jsp.

39.

• Чтобы лучше понять отличия директив,
деклараций, сценариев и выражений,
необходимо найти файл example_jsp.java
в рабочем каталоге Tomcat (\Tomcat\
work\Catalina\localhost\poem
\org\apache\jsp). В классе JSP Servlet можно
увидеть, как код из JSP был преобразован
в Java-код.

40.

Использование Директив
• Существует три разных типа директив.
• Директива свойств страницы
• Директива страницы предоставляет нам
элементы управления тем, как JSP
интерпретируется, отображается
и передается обратно клиенту. Рассмотрим
некоторые из атрибутов, которые могут
быть включены в эту директиву:

41.

42.

43.

Использование тегов

44.

• Когда Вы пишете JSP, обратите внимание,
что одна библиотека тегов уже неявно
включена для использования во всех ваших
JSP. Это библиотека тегов JSP (префикс jsp),
и Вам не нужно размещать taglib в JSP,
чтобы использовать ее. Но в документе JSP,
Вам нужно добавить объявление XMLNS
для библиотека тегов jsp.

45.

46.

47.

48.

49.

50.

51.

Компонент JavaBean

52.

Что такое JavaBean. Цели и задачи

53.

• Возможности Bean не ограничены: он может
выполнять простую функцию, такую как
проверка орфографии документа, или более
сложную — например, прогнозирование
эффективности портфеля акций. Bean может
быть, как видимым для конечного
пользователя — кнопка на графическом
пользовательском интерфейсе, так
и невидимым — программное обеспечение
для декодирования потока мультимедийной
информации в режиме реального времени.
Также Bean может быть создан для локального
использования на компьютере пользователя
или для совместной работы с набором других
распределенных компонентов.

54.

• Программное обеспечение для создания
круговой диаграммы из набора точек
данных, является примером компонента,
который может выполняться локально.
Однако, Bean который предоставляет
информацию о ценах на фондовой бирже
в реальном времени, должен
взаимодействовать с другим
распределенным программным
обеспечением для получения своих
данных.

55.

• Технология JavaServer Pages напрямую
поддерживает использование компонентов
JavaBeans со стандартными элементами
языка JSP. Вы можете легко создавать
и инициализировать компоненты, а также
получать и устанавливать значения своих
свойств.

56.

• Соглашения о разработке компонентов
JavaBeans определяют свойства класса
и публичные методы, которые
предоставляют доступ к свойствам.
• Свойство не должно быть реализовано
переменной экземпляра. Оно должно быть
доступно с использованием публичных
методов, которые соответствуют
следующим соглашениям:

57.

• В дополнение к методам свойств
компонент JavaBeans должен определять
конструктор, который не принимает
никаких параметров.

58.

59.

• Преимущество для объявления
компонента, таким образом, заключается
в том, что он делает JavaBeans доступными
для других тегов JSP. Если Вы просто
объявили JavaBean-компонент в сценарии,
он будет доступен только для сценариев
и выражений.

60.

Пример использования
• Рассмотрите пример компонента JavaBean:

61.

• JavaBean CardDB имеет свойство
clientName, которое доступно и для чтения
и для записи.
• В дополнение к методам свойств
компонент JavaBeans должен определять
конструктор по умолчанию.

62.

63.

64.

Что такое JSP Fragment?

65.

• По умолчанию веб-контейнеры
преобразовывают и компилируют файлы,
заканчивающиеся на .jsp и .jspx как JSP. Так же
существует расширение .jspf. Файлы JSPF
обычно называются фрагментами JSP и не
компилируются веб-контейнером. Хотя нет
жестких правил, регулирующих файлы JSPF,
можно технически настроить большинство
веб-контейнеров для их компиляции, если
необходимо. Файлы JSPF представляют собой
фрагменты JSP, которые не могут существовать
самостоятельно и всегда должны быть
включены, а не доступны напрямую. Вот
почему веб-контейнеры обычно не
компилируют их.

66.

• Фактически, во многих случаях файл JSPF
ссылается на переменные, которые могут
существовать только в том случае, если они
включены в другой JSP-файл. По этой
причине файлы JSPF должны быть
включены только с помощью директивы
include, потому что переменные,
определенные во включении JSP, должны
быть включены в состав включенного JSP.

67.

• Веб-приложение обычно содержит раздел
навигации, основное содержание и нижний
колонтитул веб-страницы. Использование
директивы include упрощает сохранение
фрагмента веб-страницы, и когда нам
нужно изменить раздел нижнего
колонтитула, нам просто нужно изменить
файл нижнего колонтитула, и вся страница,
которая включает его, будет изменена.

68.

• Включение страницы с использованием
директивы include будет происходить во
время выполнения страницы, когда JSP
транслирован в сервлет с помощью
контейнера JSP. Мы можем использовать
любое имя расширения файла для JSP
Fragment, используемого директивой
include.

69.

70.

71.

72.

Обработка ошибок в JSP

73.

74.

75.

76.

77.

Model View Controller
• Что такое Model View Controller? Цели
и задачи Model View Controller
• Model View Controller (MVC) — это паттерн,
используемый в разработке программного
обеспечения для отделения бизнес-логики
приложения от пользовательского
интерфейса. Как следует из названия,
паттерн MVC имеет три уровня.

78.

• Модель определяет бизнес-уровень
приложения, контроллер управляет
потоком приложения, а представление
определяет уровень представления
приложения.

79.

80.

• Хотя паттерн MVC не является
специфичным для веб-приложений, он
очень хорошо подходит для приложений
такого типа. В контексте Java модель
состоит из простых классов Java,
контроллер состоит из сервлетов,
а представление состоит из страниц JSP

81.

82.

Давайте посмотрим на каждый
слой:
• Модель. Это слой данных, который
содержит бизнес-логику системы, а также
представляет состояние приложения. Он не
зависит от уровня представления,
контроллер извлекает данные из уровня
модели и отправляет их туда, где эти
данные можно визуализировать — слой
представления.

83.

• Контроллер. Уровень контроллера
действует как интерфейс между
представлением и моделью. Он получает
запросы со слоя представление
и обрабатывает их, включая необходимые
проверки. Запросы затем отправляются на
уровень модели для обработки данных,
и как только они обрабатываются, данные
отправляются обратно в контроллер
и затем отображаются в представлении.

84.

• Представление. Этот уровень представляет
собой результат приложения, обычно это
форма пользовательского интерфейса.
Уровень представления используется для
отображения данных модели, полученных
контроллером.

85.

Примеры создания серверных
решений с помощью MVC
• Представим, у некоторого небольшого
предприятия есть веб-сайт, который
обслуживает клиентов. Необходимо
добавить приложение поддержки
клиентов, которое позволит клиентам
задавать вопросы и позволять сотрудникам
отвечать на эти вопросы.

86.

• На данном этапе проект будет довольно
простым. Он состоит из трех страниц,
обработанных doGet: список обращений,
страница для создания обращения
и страница просмотра. Он также имеет
возможность принятия запроса POST для
создания нового обращения.

87.

• Проект содержит классы Card и CardServlet.
Класс Card — простой POJO (plain old Java
objects) и выступает в качестве модели:

88.

89.

В то время как CardServlet является
контроллером:

90.

• Так как на данном этапе нам не важен
принцип хранения данных, в качестве базы
данных обращений будем использовать
Map.

91.

Реализация doGet выглядит
следующим образом:

92.

• Метод doGet использует паттерн
action/executor: действие передается через
параметр запроса, а метод doGet
отправляет запрос исполнителю (методу) на
основе этого действия. Метод doPost
аналогичен:

93.

94.

• Здесь используется метод
перенаправления. В этом случае, если
клиент выполняет POST с отсутствующим
параметром действия, его браузер
перенаправляется на страницу со списком
обращений.

95.

• Метод createCard использует параметры
запроса для заполнения объекта Card
и добавления его в базу данных.

96.

97.

• В методе createCard используется блок
synchronized для блокировки доступа к базе
данных обращений. В этом блоке кода
происходит два действия: CARD_ID
увеличивается и его значение извлекается,
а обращение добавляется в Map. Обе эти
переменные являются переменными
экземпляра Servlet, что означает, что
несколько потоков могут иметь к ним
доступ одновременно.

98.

• Включение этих действий в блок
synchronized гарантирует, что ни один
другой поток не сможет выполнять эти две
строки кода одновременно. Поток,
выполняющий этот блок кода, имеет
исключительный доступ для выполнения
блока до его завершения. Разумеется,
всегда следует соблюдать осторожность
при использовании методов или блоков
synchronized, поскольку неправильное
применение синхронизации может
привести к дедлокам.

99.

100.

101.

102.

103.

104.

105.

106.

Чтобы понять последний пункт,
рассмотрим следующие группы
свойств:

107.

Работа с файлами в JSP
(upload/download)
English     Русский Правила