Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции_CSharp_5.docx
Скачиваний:
32
Добавлен:
11.11.2019
Размер:
475.45 Кб
Скачать

5.26. Профили пользователя

Подсистема поддержки пользовательских профилей позволяет выполнять персонализацию страниц, то есть настройку страницы под конкретного пользователя. Для программиста пользовательский профиль выступает как набор свойств, которые сгруппированы в динамически сгенерированный класс. Объект этого класса доступен через свойство Profile страницы, а для постоянного хранения данных класса используется поставщик профиля (один из стандартных или специально разработанный).

Рассмотрим работу с профилями в предположении, что используется стандартный поставщик SqlProfileProvider. Естественно, для работы поставщика должен быть создан необходимый набор таблиц в БД приложения. Затем необходимо зарегистрировать SqlProfileProvider в файле web.config. Для этого необходимо определить строку подключения к базе профилей. Потом следует использовать раздел <profile> для удалений существующих поставщиков (элементом <clear>) и добавить поставщик SqlProfileProvider. Вот как должны выглядеть необходимые конфигурационные установки:

<system.web>

<profile defaultProvider="SqlProvider">

<providers>

<clear />

<add name="SqlProvider"

type="System.Web.Profile.SqlProfileProvider"

connectionStringName="SqlServices"

applicationName="TestApplication" />

</providers>

</profile>

</system.web>

Когда вы определяете поставщик, то должны указать имя, тип, строку подключения (ссылку на соответствующий элемент в конфигурационном файле) и имя веб-приложения.

После регистрации поставщика профилей необходимо определить состав свойств профиля. Это делается добавлением элемента <properties> внутрь раздела <profile>. В элементе <properties> вы размещаете по одному дескриптору <add> для каждого специфичного свойства профиля. Как минимум, элемент <add> поддерживает имя свойства:

<profile defaultProvider="SqlProvider">

<providers>

. . .

</providers>

<properties>

<add name="FirstName"/>

<add name="LastName"/>

</properties>

</profile>

Обычно также указывается тип данных (если этого не сделать, предполага­ется, что тип свойства ‑ строка). Можно специфицировать любой сериализуемый класс в качестве типа (String, Int32, DateTime). Можно также установить еще несколько атрибутов, чтобы создать более расширенные свойства. Эти атрибуты перечислены в табл. 49

Таблица 49

Атрибуты свойств профилей

Имя атрибута

Описание

name

Имя свойства

type

Полное квалифицированное имя класса, представляющего тип свойства (по умолчанию – String)

serializeAs

Формат, используемый при сериализации свойства (String, Binary, Xml или ProviderSpecific)

readonly

Если установлен в true, то свойство может быть прочитано, но не изменено (попытка изменить свойство вызовет ошибку времени компиляции). По умолчанию имеет значение false

defaultValue

Значение по умолчанию, которое будет использовано, если профиль не существует либо не включают определенного фрагмента информации. Значение по умолчанию не затрагивает сериализацию – свойства профиля записываются в БД, даже если их значения равны defaultValue

allowAnonymous

Булево значение, указывающее, должно ли свойство применяться со средствами анонимных профилей. По умолчанию равно false

provider

Поставщик профилей, который должен быть использован для управления только данным свойством. По умолчанию все свойства управляются с применением поставщика, указанного в элементе <profile>, но можно назначить для разных свойств разных поставщиков

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

Когда запускается приложение, ASP.NET создает новый класс для представления профиля, наследуя его от System.Web.Profile.ProfileBase, который служит оболочкой для коллекции установок профиля. ASP.NET добавляет по одному строго типизированному свойству к этому классу для каждого свойства профиля, определенного в файле web.config. Например, если определить строковое свойство по имени FirstName, то его значение на странице можно устанавливать следующим образом:

Profile.FirstName = "Alex";

Технически, полный профиль извлекается из постоянного хранилища, когда код в первый раз обращается к какому-либо свойству профиля. Информация профиля сбрасывается в базу данных по окончании запроса страницы. Если вы хотите сохранить профиль раньше, просто вызовите метод Profile.Save().

Если у вас есть большое количество установок в профиле и некоторые из них логически связаны между собой, то можно использовать группы свойств для достижения лучшей организации. Например:

<profile defaultProvider="SqlProvider">

<properties>

<group name="Preferences">

<add name="FirstName"/>

<add name="LastName"/>

</group>

<group name="Address">

<add name="Street" type="String" />

<add name="City" type="String" />

</group>

</properties>

</profile>

После этого вы можете обращаться к свойствам из своего кода, используя имя группы: lblCity.Text = Profile.Address.City. Группы ‑ это всего лишь замена полноценного пользовательского класса или структуры. Того же эффекта можно достичь, объявив собственный класс Address. Условие для такого класса – он должен быть сериализуем.

Для выполнения задач с профилями других пользователей можно воспользоваться классом ProfileManager (пространство имен System.Web.Profile), который предоставляет удобные статические методы, перечисленные в табл. 50. Многие из этих методов работают с классом ProfileInfo, который предоставляет информацию о профиле: имя пользователя (UserName), даты последнего обновления и последней активности (LastUpdateDate и LastActivityDate), размер профиля в байтах (Size), а также признак принадлежности анонимному пользователю (IsAnonymous). ProfileInfo не предоставляет действительных значений самого профиля.

Таблица 50

Статические методы класса ProfileManager

Имя метода

Описание

DeleteProfile()

Удаляет профиль указанного пользователя

DeleteProfiles()

Принимает массив имен пользователей и удаляет их профили

DeleteInactiveProfiles()

Удаляет профили, которые не использовались с указанного времени. Необходимо также передать значение из перечисления AuthenticationOption, чтобы указать, профили какого типа необходимо удалить (All, Anonymous или Authenticated)

GetNumberOfProfiles()

Возвращает количество записей с профилями в хранилище данных

GetNumberOfInactiveProfiles()

Возвращает количество записей с профилями, которые не использовались с указанного времени

GetAllInactiveProfiles()

Возвращает информацию профилей, которые не использовались с указанного времени. Профили возвращаются как объекты ProfileInfo

GetAllProfiles()

Извлекает все данные профилей из источника данных как коллекцию объектов ProfileInfo. Можно выбрать тип извлекаемых профилей (All, Anonymous или Authenticated). Существует перегруженная версия метода, использующая разбиение информации на страницы

FindProfilesByUserName()

Извлекает коллекцию объектов ProfileInfo, которые соответствуют определенному имени пользователя. SqlProfileProvider использует конструкцию LIKE при попытке найти соответствующее имя пользователя. Это значит, что можно применять шаблоны наподобие символа %. Существует перегруженная версия с разбиением на страницы

FindInactiveProfilesByUserName()

Извлекает информацию о профилях, которые не использовались с указанного времени. Можно отфильтровать определенные типы профилей (All, Anonymous или Authenticated) или имена пользователей, сравнивая с шаблоном