ЯЗЫК ПРОГРАММИРОВАНИЯ С# 2005 И ПЛАТФОРМА .NET 2.0. 3-е издание
Шрифт:
Таблица 24.3. Члены типа HttpApplicationState
Члены | Описание |
---|---|
AllKeys | Свойство, возвращающее массив типов System.String, представляющих все имена в рамках типа HttpApplicationState |
Count | Свойство, возвращающее значение числа объектов в типе HttpApplicationState |
Add | Метод, позволяющий добавить новую пару "имя-значение" в тип HttpApplicationState. Этот метод используется достаточно редко, поскольку
|
Clear | Метод, удаляющий все элементы из типа HttpApplicationState. Функционально эквивалентен методу RemoveAll |
Lock Unlock | Эти два метода используются тогда, когда требуется изменить набор переменных приложения в реентерабельной форме |
RemoveAll Remove RemoveAt | Эти методы удаляют конкретный элемент типа HttpApplicationState (по имени строки или, как RemoveAt, с помощью числового индексатора) |
Для создания членов-данных, которые должны быть доступны всем активным сеансам, нужно создать множество пар имен и значений. В большинстве случаев наиболее подходящим для этого местом является обработчик события Application_Start типа, производного от HttpApplication, например:
В течение всего времени существования Web-приложения (т.е. пока Web-приложение не будет закрыто вручную или пока не истечет время ожидания последнего пользователя) любой пользователь (на любой странице) при необходимости может получить доступ к этим значениям. Предположим, что у вас есть страница, которая по щелчку мыши должна отображать в поле Label информацию об автомобиле, предлагаемом со скидкой в данный момент.
Как и в случае свойства ViewState, обратите внимание на то, что вы должны преобразовать значение, возвращаемое типом HttpApplicationState, в подходящий тип. Поскольку тип HttpApplicationState может содержать любой тип, должно быть очевидно, что в рамках данных состояния приложения узла вы можете размещать пользовательские типы (и вообще любые типы .NET).
Для примера использования этой возможности создайте новое Web-приложение ASP.NET с названием AppState. Предположим, что требуется поддерживать три текущие переменные приложения в рамках строго типизованного объекта с именем CarLotlInfo.
С
этим вспомогательным классом вы можете сначала изменить обработчик события Application_Start так, как предлагается ниже:а затем получить доступ к соответствующей информации с помощью открытых полей данных в обработчике событий сервера.
Открыв сейчас эту страницу, вы обнаружите, что в поле типа Label страницы отображаются строки каждой из переменных приложения.
Изменение данных состояния приложения
В ходе выполнения Web-приложения с помощью членов типа HttpApplicationState вы можете программно модифицировать или удалить любые или даже все члены уровня приложения. Например, чтобы удалить конкретный элемент, нужно просто вызвать метод Remove. Чтобы уничтожить все данные уровня приложения, вызовите RemoveAll.
Чтобы изменить значение существующей переменной уровня приложения, нужно присвоить новое назначение соответствующему элементу данных. Предположим, что ваша страница поддерживает еще один тип Button, который дает пользователю возможность изменить имя наиболее удачливого продавца. Обработчик события Click в этом случае выглядит так, как и ожидается.
Запустив это Web-приложение, вы увидите, что переменная уровня приложения обновлена. К тому же, поскольку переменные приложения доступны для всех сеансов пользователей, если запустить три или четыре экземпляра Web-браузера, вы увидите, что при изменении имени лучшего продавца одним экземпляром все остальные экземпляры браузера после вторичного обращения к серверу тоже отобразят новое значение.