
- •Введение
- •1 Тема 1. Предметная область и терминология РСОС
- •1.1 Этапы развития распределенных систем
- •1.1.1 Классификация систем обработки данных
- •1.1.2 Распределенные вычислительные сети
- •1.1.3 Объектные распределенные системы
- •1.2 Становление систем с сервис-ориентированной архитектурой
- •1.2.1 Развитие web-технологий
- •1.2.2 Развитие концепции SOA
- •1.3 Современные парадигмы сервис-ориентированных архитектур
- •1.3.1 Эталонная модель SOA
- •1.3.2 Модель Захмана
- •1.3.3 Концепция среды открытой системы
- •1.3.4 Бизнес-парадигма модели SOA
- •1.4 Программная платформа Java Enterprise Edition
- •1.4.1 Контейнеры и компоненты Java EE
- •1.4.2 Служебные сервисы контейнеров
- •1.4.3 Артефакты контейнеров
- •1.4.4 Аннотации и дескрипторы развертывания
- •1.4.5 Управляемые компоненты платформы Java EE
- •1.5 Инструментальные средства реализации РСОС
- •1.5.1 Сервера приложений
- •1.5.2 Микросервисы
- •1.5.3 Apache Maven — сетевая сборка приложений
- •1.5.4 Eclipse Enterprise Edition
- •1.5.5 Тестовый пример
- •1.6 Заключение по первой главе
- •1.6.1 Итоги теоретических построений первой главы
- •1.6.2 Тематический план последующих глав
- •Вопросы для самопроверки
- •2 Тема 2. Использование компоненты JSF контейнера Web
- •2.1.1 Языки HTML, JavaScript и протокол HTTP
- •2.1.2 Серверные технологии PHP и HttpServlet
- •2.1.3 Технология AJAX и компонента JavaServer Faces
- •2.2 Шаблон проектирования MVC
- •2.2.1 Контроллер FacesServlet и жизненный цикл запроса
- •2.2.2 Контекст состояния запроса FacesContext
- •2.2.3 Модель в виде компонентов-подложек
- •2.2.4 Представление (View) средствами Facelets
- •2.2.5 JSF OmniFaces
- •2.3 Реализация тестового примера средствами JSF
- •2.3.1 Создание Facelets-шаблона изучаемой дисциплины
- •2.3.2 Прямая реализация тестового примера
- •2.4 Реализация уровня интерфейса сервисов
- •2.4.2 Компонента Users с ЖЦ @ApplicationScoped
- •2.4.3 Компонента RSOS с ЖЦ @SessionScoped
- •2.4.4 Компоненты-подложки с ЖЦ @RequestScoped
- •2.4.5 Приложение авторизации пользователя
- •2.4.6 Компонента подзаголовка проекта
- •2.4.7 Компонента меню лабораторных работ
- •2.4.8 Второй вариант меню лабораторных работ
- •Вопросы для самопроверки
- •3 Тема 3. Современные способы доступа к данным
- •3.1 Учебная инфраструктура темы
- •3.1.1 Учебная задача Letters (Письма)
- •3.1.2 Корпоратиные EJB-компоненты
- •3.1.3 Тестовый HttpServlet проекта lab4
- •3.1.4 Инфраструктура сервера TomEE и СУБД Derby
- •3.2 Технология JPA
- •3.2.1 Сущности
- •3.2.2 Объектно-реляционное отображение
- •3.2.3 Манеджер сущностей
- •3.2.4 Пример использования не-JTA-типа транзакций
- •3.3 Транзакции управляемые контейнером
- •3.3.1 Объектно-ориентированные запросы Criteria API
- •3.3.2 Реализация EJB-компонента с JTA-типом транзакций
- •3.3.3 Реализация JPA-сервлета
- •Вопросы для самопроверки
- •4 Тема 4. Обработка документов XML и JSON
- •4.1 Технология JAXB
- •4.1.1 Программное обеспечение технологии JAXB
- •4.1.2 Аннотации для связывания объектов Java
- •4.1.3 Преобразование объекта Java в документ XML
- •4.2 Технология JSON
- •4.2.1 Программное обеспечение технологии JSON
- •4.2.2 Преобразование объекта Java в документ JSON
- •4.2.3 Пример представления JSON на уровне классов
- •4.2.4 Выводы по результатам изучения главы 4
- •Вопросы для самопроверки
- •5 Тема 5. Web-службы SOAP
- •5.1.1 Протоколы и языки Web-служб
- •5.1.2 Краткое описание языка WSDL
- •5.1.3 Краткое описание протокола SOAP
- •5.1.4 Необязательный реестр Web-служб — UDDI
- •5.1.5 Программные пакеты Java EE, обслуживающие SOAP
- •5.2 Создание Web-служб SOAP
- •5.2.1 Подготовка проекта lab7
- •5.2.2 Аннотации поставщика Web-сервиса
- •5.2.3 Обработка исключений поставщика Web-сервиса
- •5.2.4 Обработка контекста Web-сервиса
- •5.3 Создание потребителя Web-службы SOAP
- •5.3.1 Аннотации для потребителей сервиса
- •5.3.2 Использование утилиты wsimport
- •5.3.3 Реализация тестового примера
- •5.3.4 Выводы по результатам изучения главы 5
- •Вопросы для самопроверки
- •6 Тема 6. Web-службы в стиле REST
- •6.1 Основные положения технологии RESTful
- •6.1.1 Ресурсы, URI, представления и адресуемость
- •6.1.2 Протокол HTTP
- •6.1.3 Языки WADL и HAL
- •6.1.4 Технология JAX-RS
- •6.2 Реализация Web-службы в стиле REST
- •6.2.1 Преобразование сущности Letter
- •6.2.2 Реализация EJB-компоненты Lets9
- •6.2.3 Получение списка записей в формате XML
- •6.2.4 Получение записи по номеру индентификатора
- •6.2.5 Добавление новой записи
- •6.3 Вызов Web-служб в стиле REST
- •6.3.1 Инструментальные средства потребителя сервиса
- •6.3.2 Полная реализация RESTfull-сервиса
- •6.3.3 Шаблон реализации потребителя сервиса
- •6.3.4 Клиент, реализующий методы GET и POST
- •6.3.6 Клиент, реализующий методы DELETE и PUT
- •Вопросы для самопроверки
- •Заключение
- •Список использованных источников
- •Алфавитный указатель

в) задачи отображения меню работ, представленная файлом Web-ре-сурса menus3.xhtml и компонентом-подложкой Menus3.
Последующие пункты демонстрируют решение этих задач.
Браузер
клиента
<Web-ресурс> |
|
<Web-ресурс> |
|
<Web-ресурс> |
|||
auth3.xhtml |
|
subheader3.xhtml |
|
menus3.xhtml |
|||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Запрос> |
|
<Запрос> |
|
<Запрос> |
|||
Auth3.class |
|
SubHeader3.class |
|
Menus3.class |
|||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Сессия> |
|
|
|
|
|
|
|
RSOS.class |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Приложение> |
|
|
|
|
|
|
|
Users.class |
|
|
|
Рисунок 2.26 — Схема взаимодействия браузера и компонент-подложек JSF проекта labs
2.4.5 Приложение авторизации пользователя
Функциональность задачи авторизации пользователя обеспечивается CDI-компонентом Auth3 с ЖЦ @RequestScoped.
Решение задачи авторизации обеспечивается тремя объектными приватными данными: инекцией CDI-компоненты RSOS (rsos) и двумя строковыми переменными (user и password). Ее непосредственная функциональность обеспечивается двумя методами:
а) String loginAuth() — авторизация по имени и паролю пользователя с последующим переходом на заданный Web-ресурс;
б) String logoutAuth() — сброс результата авторизации с последующим переходом на заданный Web-ресурс.
Результат реализации Auth3 представлен на листинге 2.21.
110
Листинг 2.21 — Исходный текст класса Auth3.java проекта labs
package asu.rsos;
import javax.annotation.PostConstruct;
import javax.enterprise.context.RequestScoped; import javax.inject.Inject;
import javax.inject.Named;
@Named
@RequestScoped public
class Auth3
{
/**
* Инъекция объекта класса RSOS */
@Inject
private RSOS rsos;
//Атрибут имени пользователя private String user = "";
//Атрибут пароля пользователя private String password = "";
/** * Пустой конструктор */
public Auth3() {}
//Для демонстрации @PostConstruct private void test() {
System.out.println("Объект класса Auth3 - стартовал...");
}
//Стандартная обработка атрибутов
public String getUser()
{
System.out.println("Auth3: getUser() = " + user); return user;
}
public void setUser(String user)
{
System.out.println("Auth3: setUser() = " + user); this.user = user;
}
public String getPassword() {return password;}
public void setPassword(String password) {this.password = password;}
/** * Метод проведения авторизации и
111

* переход на нужный ресурс */
public String loginAuth()
{
rsos.loginRSOS(user, password); user = rsos.getUser();
if(user == null || rsos.getWork() == null) return "default";
// Запускаем ресурс работы String ss = rsos.getXHTML(); if(ss == null) return "default"; return ss;
}
/**
*Метод сброса результата авторизации и
*переход на нужный ресурс
*/
public String logoutAuth()
{
rsos.logoutRSOS(); user = null;
return "default";
}
}
За отображение задачи авторизации отвечает Web-ресурс auth3.xhtml, переопределяющий шаблон lab3Templ.xhtml с именем "context".
Заявленный Web-ресурс полностью опирается на функциональность своей компоненты-подложки и содержит: поля ввода имени и пароля пользователя, а также кнопку запроса, представленные на листинге 2.22. Результат разработки этого приложения представлен на рисунке 2.27.
Листинг 2.22 — Исходный текст файла auth3.xhtml проекта labs
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:ui="http://xmlns.jcp.org/jsf/facelets" xmlns:h="http://xmlns.jcp.org/jsf/html" xmlns:f="http://xmlns.jcp.org/jsf/core" xml:lang="ru">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>Приложение auth3</title>
</head>
<body>
<ui:composition template="/WEB-INF/templates/lab3Templ.xhtml"> <ui:define name="context">
<div style="color:black; width:100%; padding:10px">
112

<b>Авторизация пользователя</b> <hr/>
<h:form>
<h:panelGrid columns="2">
<h:outputText value="Имя:"></h:outputText> <h:inputText value="#{auth3.user}"/> <h:outputText value="Пароль:"></h:outputText>
<h:inputSecret value="#{auth3.password}"></h:inputSecret> </h:panelGrid>
<h:commandButton value="Авторизация" action="#{auth3.loginAuth()}"></h:commandButton>
<h:commandButton value="Отказаться" action="#{auth3.loginAuth()}"></h:commandButton>
</h:form> </div> </ui:define>
</ui:composition> </body>
</html>
Рисунок 2.27 — Результат разработки приложения авторизации пользователя
113