Apache Tapestry - Хранение

Каждое веб-приложение должно иметь способ хранить определенные пользовательские данные, такие как объект пользователя, пользовательские настройки и т. Д. Например, в приложении корзины покупок выбранные пользователем элементы / продукты должны сохраняться во временном сегменте (корзине) до тех пор, пока пользователь не предпочтет покупать продукцию. Мы можем сохранить товары в базе данных, но это будет слишком дорого, так как не все пользователи будут покупать выбранные товары. Итак, нам нужно временное устройство для хранения / сохранения элементов. Apache Tapestry предоставляет два способа сохранения данных, и они:

  • Данные страницы сохраняемости
  • Хранение сессий

У обоих есть свои преимущества и ограничения. Мы проверим это в следующих разделах.

Данные страницы сохраняемости

Данные страницы сохранения состояния - это простая концепция для сохранения данных на одной странице между запросами, которую также называют Page Level Persistence. Это можно сделать с помощью@Persist аннотация.

@Persist 
public int age;

Как только поле аннотируется с помощью @Persist, значение поля будет сохраняться в запросе, и если значение будет изменено во время запроса, оно будет отражено при следующем доступе к нему. Apache Tapestry предоставляет пять типов стратегии для реализации концепции @Persist. Они следующие -

  • Session Strategy - Данные сохраняются с использованием сеанса, и это стратегия по умолчанию.

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

@Persist(PersistenceConstants.FLASH) 
private int age;
  • Client Strategy - Данные сохраняются на стороне клиента, такие как строка запроса URL, скрытое поле в форме и т. Д.

@Persist(PersistenceConstants.FLASH) 
private int age;
  • Hibernate Entity Strategy- Данные сохраняются с использованием модуля Hibernate как Entity. Сущность будет сохранена в Hibernate, а ее ссылка (имя класса Java и его первичный ключ) будет сохранена как токен вHttpSession. Сущность будет восстановлена ​​с помощью токена, доступного в HttpSession.

@Persist(HibernatePersistenceConstants.ENTITY) 
private Category category;
  • JPA Entity Strategy- Данные сохраняются с помощью модуля JPA. Он сможет хранить только Entity.

@Persist(JpaPersistenceConstants.ENTITY) 
private User user;

Хранение сессий

Сессионное хранилище - это расширенная концепция, используемая для хранения данных, которые должны быть доступны на разных страницах, таких как данные в многостраничном мастере, данные пользователя и т. Д. Хранилище сеансов предоставляет два варианта: один для хранения сложного объекта, а другой - для хранения простых значений.

  • Session Store Object - Используется для хранения сложного объекта.

  • Session Attributes - Используется для хранения простых значений.

Объект хранилища сеансов (SSO)

SSO можно создать с помощью @SessionStoreаннотация. SSO сохранит объект, используя тип объекта. Например,Cart Objectбудет храниться с использованием имени класса Cart в качестве токена. Таким образом, любой сложный объект может быть сохранен в приложении один раз (по одному на пользователя).

public class MySSOPage { 
   @SessionState 
   private ShoppingCart cart; 
}

SSO - это специализированное хранилище, и его следует использовать для хранения только сложных / специальных объектов. Простые типы данных также могут быть сохранены с использованием единого входа, но хранение простых типов данных, таких как String, позволяет сохранять только одно значение «String» в приложении. Использование единственного значения String в приложении просто невозможно. Вы можете использовать простые типы данных, поскольку Apache Tapestry предоставляет атрибуты сеанса.

Атрибуты сеанса

Атрибуты сеанса позволяют хранить данные по имени, а не по типу.

public class MyPage { 
   @SessionAttribute  
   private String loggedInUsername; 
}

По умолчанию атрибуты сеанса используют имя поля для ссылки на данные в сеансе. Мы можем изменить имя ссылки с помощью параметра аннотации, как показано ниже -

public class MyPage { 
   @SessionAttribute("loggedInUserName") 
   private String userName; 
}

Одна из основных проблем при использовании имени в качестве ссылки на сеанс заключается в том, что мы можем случайно использовать одно и то же имя в нескольких классах / страницах. В этом случае сохраненные данные могут неожиданно измениться. Чтобы решить эту проблему, лучше использовать имя вместе с именем класса / страницы и именем пакета, напримерcom.myapp.pages.register.email, где com.myapp.pages - это имя пакета, register - это имя страницы / класса и, наконец, электронная почта - это имя переменной (для сохранения).