Обычно необходимость в определении того, что текущий HTTP-запрос является вторичным, возникает тогда, когда некоторый блок программного кода должен выполняться только при первом обращении пользователя к странице. Например, при первом доступе пользователя к файлу *.aspx вы можете заполнить некоторый объект DataSet ADO.NET и поместить этот объект в кэш для использования в дальнейшем. Когда вызывающая сторона снова обратится к той же странице, вы можете избежать необходимости нового обращения к базе данных (конечно, некоторые страницы могут требовать, чтобы DataSet обновлялся при каждом запросе, но это уже другая проблема).
protected void Page_Load(objeet sender, EventArgs e) {
// DataSet заполняется только при первом обращении
// пользователя к данной странице.
if (!IsPostBack) {
// Заполнение DataSet и отправка в кэш!
}
// Использование DataSet из кэша.
}
Взаимодействие с исходящим HTTP-ответом
Теперь вы понимаете, как тип Page взаимодействует с поступающим HTTP-за-просом, и следующим шагом должно быть выяснение того, как реализуется взаимодействие с исходящим HTTP-ответом. В ASP.NET свойство Response класса Page обеспечивает доступ к экземпляру типа HttpResponse. Этот тип определяет ряд свойств, позволяющих сформировать HTTP-ответ, отправляемый обратно браузеру клиента. Описания базовых свойств этого типа предлагаются в табл. 23.6.
Таблица 23.6.Свойства типа HttpResponse
Свойство |
Описание |
Cache |
Возвращает семантику кэширования Web-страницы (например, время ожидания, параметры конфиденциальности, различные описания) |
ContentEncoding |
Читает или устанавливает набор символов выходного потока HTTP |
ContentType |
Читает или устанавливает MIME-тип выходного потока HTTP |
Cookies |
Получает коллекцию HttpCookie, посланную текущим запросом |
IsClientConnected |
Читает значение, являющееся индикатором продолжающегося соединения клиента с сервером |
Output |
Разрешает пользовательский вывод в поле содержимого исходящего HTTP-сообщения |
OutputStream |
Разрешает двоичный вывод в поле содержимого исходящего HTTP-сообщения |
StatusCode |
Читает или устанавливает код состояния HTTP-ответа, возвращаемого клиенту |
StatusDescription |
Читает или устанавливает строку состояния HTTP-ответа, возвращаемого клиенту |
SuppressContent |
Читает или устанавливает значение, являющееся индикатором отмены отправки HTTP-содержимого клиенту |
Рассмотрите также описания некоторых методов типа HttpResponse, представленные в табл. 23.7.
Таблица 23.7.Методы типа HttpResponse
Метод |
Описание |
AddCacheDependency() |
Добавляет объект в кэш приложения (см. главу 24) |
Clear() |
Удаляет все заголовки и содержимое вывода из буфера потока |
End() |
Отправляет все содержимое буфера вывода клиенту, а затем завершает соединение для данного сокета |
Flush() |
Отправляет все содержимое буфера вывода клиенту |
Redirect() |
Выполняет перенаправление клиента по новому URL |
Write() |
Записывает значения в выходной поток HTTP-содержимого |
WriteFile() |
Записывает файл непосредственно в выходной поток HTTP-содержимого |
Генерирование HTML-содержимого
Пожалуй, самой известной сферой применения типа HttpResponse является запись содержимого непосредственно в выходной поток HTTP. Метод HttpResponse. Write() позволяет передать HTML-дескрипторы, или вообще любые строковые литералы. Метод HttpResponse.WriteFile() расширяет эти возможности с тем, чтобы вы могли указать имя физического файла на Web-сервере, содержащего данные, направляемые в выходной поток (это оказывается очень удобным в том случае, когда требуется отправить содержимое уже существующего файла *.htm).
Для примера предположим, что вы добавили в свой файл *.aspx еще один тип Button, который реализует обработчик события Click сервера так.
protected void btnHttpResponse_Click(object sender, EventArgs e) {
Response .Write("‹b›Moe имя :‹/b›‹br›");
Response .Write(this.ToString());
Response .Write("‹br›‹br›‹b›Boт Ваш последний запрос:‹/b›‹br›");
Response. WriteFile("MyHTMLPage.htm");
}
Роль этой вспомогательной функции (которая может вызываться некоторым: обработчиком события на стороне сервера) очень проста. Единственным заслуживающим внимания моментам здесь является то, что метод HttpResponse. WriteFile() теперь отправляет содержимое файла *.htm сервера из корневого каталога Web-узла.
Читать дальше