Майкл Оути старший технический редактор в журналах SQL Server Magazine и Windows NT, президент компании ТЕСА
Основы интерактивного WEB-дизайна
Программный продукт ASP, название которого в переводе означает
Активные страницы сервера (Active Server Pages), обеспечивает
написание сценариев серверной части для информационных WEB-серверов
компании Microsoft, IIS (Internet Information Server). Впервые
корпорация Microsoft ввела ASP в версии IIS 3.0, и продолжила
дальнейшую разработку этого продукта в IIS 4.0. ASP представляет
собой гибкое динамичное средство создания WEB-страниц и позволяет
применять любой язык написания сценариев, удовлетворяющий стандарту
ActiveX. Как правило, ASP использует комбинацию из HTML и
встроенного VBScript. IIS включает в себя сервер автоматизации OLE,
который исполняет VBScript и посылает результаты реализации сценария
в формате HTML клиенту, который может иметь только браузер. Так как
сценарии ASP выполняются на сервере, то ASP способен работать с
любым WEB-браузером, поскольку браузер получает лишь поток страниц
HTML. Понимание того, каким образом объекты ADO работают с ASP, и в
особенности того, как лучше применять объекты ADO для поиска и
модификации данных, может превратить создание динамических
WEB-страниц в легкое и приятное занятие.
Как работает ASP
|
Рисунок 1. Обзор взаимодействия ASP и
HTML 1- WEB-сервер 2- Клиент WEB 3- Активный
сценарий 4- пример .ASP |
На рисунке 1 изображено, как ASP комбинирует сценарий ActiveX и
команды HTML для того, чтобы получить динамическую страницу HTML.
Как следует из рисунка, сценарии ASP отличаются от сценариев,
базирующихся на браузерах. В традиционных сценариях, основывающихся
на браузерах, WEB-сервер посылает страницу HTML, содержащую сценарий
ActiveX в браузер клиента, который и отвечает за выполнение
сценария. Подход, при котором основной акцент делается на клиентской
части приложения, возлагает на нее дополнительный груз обязанностей,
что может привести к возникновению проблем, если клиентский браузер
не будет в состоянии выполнить сценарий. Напротив, страницы ASP
исполняются на WEB-сервере IIS. В ходе исполнения страницы сервер
напрямую посылает клиенту команды HTML и все клиентские сценарии,
содержащиеся на странице ASP. Но как только сервер доходит до
команды серверного сценария ASP, то он исполняет этот сценарий и
передает клиенту в форме HTML только полученные в качестве
результата выходные данные. Клиент, действия которого сводятся к
использованию браузера, не видит разницы между потоком страниц HTML,
порождаемым сценарием ASP, и потоком HTML, посылаемым статичными
WEB-страницами. Таким образом, написание сценариев для серверной
стороны с помощью ASP создает WEB-страницы, которые выступают в
качестве исполнителей сценариев. Тот факт, что ASP генерирует только
поток страниц HTML, обеспечивает независимость от типа браузера
клиента. В силу того, что сервер IIS интерпретирует страницы ASP 'на
лету', ASP служит идеальным средством для встраивания результатов
обработки интерактивных запросов к базе данных в WEB-страницы. Эти
возможности обеспечиваются доступом к базе данных SQL Server через
ADO непосредственно со страниц ASP.
Будь то доступ из Internet или из местной сети Intranet, клиенты
применяют протоколы HTTP и TCP/IP для связи с WEB- сервером IIS.
Когда WEB-клиент запрашивает страницу ASP, WEB-сервер IIS сценарии,
находящиеся на этой странице. Для того чтобы получить доступ к базе
данных SQL Server, сценарий ASP открывает соединение с SQL Server с
помощью одного из объектов Соединение, Команда или Набор записей.
Затем использует этот объект для передачи в сервер запроса на доступ
к данным. SQL Server может размещаться на том же компьютере, что и
WEB-сервер IIS. Однако в силу того, что часто SQL Server
используется одновременно сразу несколькими различными приложениями,
удобнее разместить его на отдельном компьютере, и обеспечить связь с
ним через локальную сеть. После того как ядро SQL Server закончит
обработку запроса, оно возвращает результаты объекту ADO из сценария
ASP. Затем IIS продолжает исполнять сценарий ASP и отсылает поток
страниц HTML обратно клиенту. Поэтому обязательно должно
существовать сетевое соединение между WEB-сервером IIS и сервером
баз данных SQL Server. Кроме того, на WEB-сервере необходимо
установить поставщик OLE DB и библиотеки DLL на период прогона
ADO.
Использование объектов ADO на страницах ASP
При использовании ADO приложение первым делом пытается применить
объекты Соединение, Команда или Набор записей для установления
соединения с SQL Server. Объект Соединение следует употреблять для
того, чтобы открыть соединение ADO явным образом. Объекты Команда и
Набор записей позволяют сделать то же самое динамически. После
установления соединения приложение ASP может выполнять команды ADO
такого же типа, что и стандартное приложение, написанное на Visual
Basic (VB). Эти команды включают исполнение хранимых процедур,
открытие и просмотр набора записей, вставку, обновление и удаление
данных.
Для подключения страницы ASP к серверу баз данных SQL Server ADO
может применять поставщик OLE DB как для ODBC, так и для SQL Server.
Поставщик OLE DB для ODBC позволяет использовать структуру объекта
ADO с большинством существующих драйверов ODBC. Но поставщик OLE DB
для SQL Server дает возможность подключиться только к SQL Server.
Однако с объектами ADO Соединение, Команда и Набор записей возможно
применять любой из упомянутых поставщиков. Листинг 1 (написанный на
языке VBScript) показывает, как применить поставщик OLE DB для ODBC
в целях установления соединения с SQL Server.
Первое действие, проводимое в листинге 1, это объявление трех
переменных, которые будут содержать имя компьютера, на котором
размещен SQL Server, и информации для аутентификации SQL Server.
Затем сценарий декларирует переменную cn, которую он в последствии
будет использовать для объекта ADO Соединение. После объявления в
сценарии рабочих переменных метод Формировать (Form) объекта ASP
Запрос (Request) присваивает значения всем этим переменным.
Следующим шагом метод Создать объект (CreateObject) объекта ASP
Сервер (Server) создает новый объект ADO Соединение (Connection),
который затем присваивается введенной ранее переменной cn. Метод
Создать объект (CreateObject) способен порождать экземпляры объектов
СОМ. Данный пример иллюстрирует создание экземпляра объекта
Соединение ADODB (ADODB.Connection), но его можно аналогичным
образом применять и для других структур объектов СОМ, например, для
SQL-DMO или Active Directory. (Более подробную информацию об
объектах ASP можно найти во врезке 'Модель объектов ASP').
После этого сценарий присваивает значение строки соединения OLE
DB свойству Строка соединения (ConnectionString) объекта Соединение,
хранящегося в переменной cn. Это позволяет установить соединение без
указания имени источника данных, DSN (Data Source Name). В силу
того, что спецификация поставщика OLE DB проводилась без ключевого
слова PROVIDER, по умолчанию берется поставщик OLE DB для ODBC.
Ключевое слово DRIVER идентифицирует тот драйвер, который
предполагается применять в дальнейшем. За ключевым словом SERVER
указывается имя компьютера, содержащего SQL Server, с которым
намереваются установить соединение. За ключевыми словами UID и PWD
содержится информация, необходимая для входа в систему. Ключевое
слово DATABASE определяет, что в роли базы данных, используемой по
умолчанию, будет выступать база данных pubs. После того как будет
присвоено значение строки соединения свойству Строка соединения
(ConnectionString) объекта Соединение (Connection), его метод
Открыть (Open) установит соединение с SQL Server, удовлетворяющее
всем значением параметров, заданных в сценарии.
Поиск данных с помощью объекта ADO Набор записей ()
ADO можно применять для поиска данных с помощью объектов Набор
записей (Recordset) или Команда (Command). Оба эти объекта способны
работать с активным объектом Соединение (Connection), или же
создавать новое отдельное соединение. Каждый раз, когда объект
Соединение (Connection) или Набор записей (Recordset) устанавливает
соединение, начинается новая коммуникационная сессия с SQL Server.
Поэтому в том случае, если приложению необходимо выполнить несколько
операций, целесообразнее применить объект Соединение (Connection)
для открытия связи с SQL Server. Этот объект будет использоваться
объектами Команда (Command) или Набор записей (Recordset).
Листинг 2 демонстрирует применение объекта ADO Набор записей
(Recordset) на странице ASP. Первая часть сценария во многом
напоминает простой пример установления соединения, приведенный в
листинге 1. В сценарии сначала декларируются рабочие переменные, а
затем им присваиваются значения. После этого по сценарию создается
объект Соединение (Connection), и вслед за ним объект ADO Набор
записей (Recordset). На следующем шаге сценария строка соединения
присваивается объекту ADO Соединение (Connection), и затем для
установления связи с SQL Server вызывается метод Открыть (Open). В
соответствии со сценарием свойству Активное соединение
(ActiveConnection) объекта Набор записей (Recordset), хранящегося в
переменной rs, передается значение объекта активного соединения, cn,
и выполняется метод Открыть (Open) объекта Набор записей
(Recordset). Первый параметр метода Открыть (Open) содержит простой
оператор SQL, который выбирает все столбцы и строки из таблицы
stores базы данных Pubs.
После того как сценарий возвращает результаты обработки запроса,
страница ASP создает таблицу HTML, содержащую шесть столбцов. После
этого по сценарию столбцы получают заголовки. Сценарий использует
стандарт HTML для построения всех заголовков столбцов. Внутри тела
таблицы HTML в соответствии с меткой А листинга 2 программный код
VBScript организует цикл Do Until. Этот цикл обрабатывает содержимое
объекта Набор записей (Recordset), находящегося в переменной rs.
Когда сценарий доходит до конца объекта Набор записей (Recordset),
свойство rs.EOF получает значение Истина, и цикл завершается.
Встроенный в страницу ASP сценарий присваивает значения всем
столбцам исходя из имени столбца объекта ADO Набор записей
(Recordset). В рассматриваемом примере имя столбца, происходящее из
таблицы Stores базы данных Pubs идентифицирует каждый пункт
коллекции Поля (Fields). Расположенная вслед за этим часть кода
VBScript реализует метод MoveNext для перехода к следующей строке в
объекте Набор записей (Recordset). Затем оператор Цикл (Loop)
возвращает управление в начало цикла Do Until. Когда этот цикл
прочитает последнюю строку набора записей, цикл заканчивается и
объекты Набор записей (Recordset) и Соединение (Connection),
хранившиеся соответственно в переменных rs и cn, закрываются.
Результаты работы этой страницы ASP можно видеть на экране 1.
|
Экран 1. Просмотр простого объекта
ADO Набор записей |
Изменение данных средствами ADO
ASP и ADO можно применять не только для динамической выдачи
WEB-страниц, но и в целях создания WEB-страниц для ввода данных.
Такая возможность позволяет создавать основанные на WEB приложения с
использованием баз данных, обладающие таким же набором функций
работы с базами данных, что и стандартные приложения, разработанные
в соответствии с архитектурой клиент-сервер. Объекты ADO Набор
записей (Recordset), которые становятся доступными на страницах ASP,
предоставляют тот же перечень услуг, что и приложения, написанные на
Visual Basic. Как показывает следующий пример, их можно применять
для ввода данных. Кроме того, их можно использовать для изменения
или удаления данных. Все остальные возможности ADO, такие как
способность запускать подготовленные заранее операторы SQL или
хранимые процедуры, также имеют место.
В целях внесения изменений в данные возможности, предоставляемые
ASP и ADO, можно комбинировать различными способами. К примеру,
можно было бы создать страницы ASP, которые будут поддерживать
изменяемые объекты ADO Набор записей (Recordset). Они, в свою
очередь, смогут применять методы Добавить новый (AddNew), Обновить
(Update) и Удалить (Delete) для модификации данных в базах SQL
Server. Помимо этого, возможно применять ADO для выполнения как
динамических,, так и подготовленных заранее с помощью языка SQL
операций модификации данных. Код приведенный на листинге 3,
иллюстрирует, каким образом можно было бы добавлять строки в объект
Набор записей (Recordset), который создается с использованием
курсора Keyset.
Листинг 3 представляет дополнительные технические приемы
построения WEB-приложений с помощью ASP. Первая строка является
оператором VBScript Option Explicit, который указывает, что все
переменные в коде VBScript перед их применением будут явным образом
продекларированы. Как и в стандартном Visual Basic, в VBScript
предусмотрено автоматическое использование новых переменных, без их
предварительного объявления. На первый взгляд это свойство может
показаться очень удобным, но в реальности оно служит довольно
эффективным способом ввести в разрабатываемое приложение ASP
множество трудно находимых коварных ошибок.
Следующим шагом оператором #include вводится файл adovbs.inc.
Оператор #include представляет очень удобный путь копирования обычно
употребляемых констант на страницы ASP. В данном случае файл
adovbs.inc включает все константы, которые обычно содержит структура
объекта ADO. Подключение этого файла дает возможность записывать
константы в виде adChar и adKeyset, а не в виде значений,
представляемых этими константами. Применение констант делает код
удобно читаемым и легким в сопровождении. Хотя включение файла
является хорошим приемом для средств разработки вообще, но в случае,
когда для создания ASP- приложений используется такой инструмент,
как Visual InterDev (VID), можно просто добавить в среду разработки
VID ссылку на объектную библиотеку ADO. Подобное добавление
устраняет необходимость включения файла в ASP- приложения. Чтобы
добавить ссылку на ADO в проект VID следует выбрать в меню Проект
(Project) и Ссылки проекта (Project References), а затем выбрать в
списке доступных ссылок библиотеку Microsoft ActiveX Data Library
2.0.
В соответствии со сценарием VBScript, приведенным на листинге 3,
сначала уничтожается, а затем воссоздается заново таблица в базе
данных pubs, после чего в эту таблицу вставляются 50 строк и
полученное содержимое показывается на WEB-странице. Но прежде чем
выполнить все это, в том месте сценария, которое отмечено в листинге
3 буквой А, инициируется обработчик ошибок VBScript. В этом примере
оператор On Error применен для того, чтобы обойти любые ошибки,
которые могут произойти, к примеру, при попытке удалить
несуществующую таблицу из указанной базы данных. В следующем разделе
будет более подробно рассмотрено использование обработчика
ошибок.
На следующем шаге сценарий ставит в соответствие переменной cn
объект ADO Соединение (Connection). Затем метод Исполнить (Execute)
объекта Соединение (Connection) выполняет два динамических оператора
SQL. Первый уничтожает таблицу Department, а второй создает таблицу
Department заново. После создания таблицы Department сценарий
устанавливает в свойстве Активное соединение (ActiveConnection)
объекта Набор записей (Recordset), указанного в переменной rs,
ссылку на этот объект Соединение (Connection). Затем метод Открыть
(Open) объекта Набор записей (Recordset) создает обновляемый набор
записей. Константа adOpenKeyset определяет, что этот объект будет
относиться к обновляемому типу Keyset, а константа adLockOptimistic
предписывает использование оптимистического типа блокировки
записей.
Цикл For Next вставляет 50 строк в таблицу Department. В этом
цикле метод Добавить новый элемент (AddNew) создает буфер для
хранения новой строки, после чего цикл присваивает значения объектам
ADO Поле (Field). Каждый объект коллекции Поле (Field)
идентифицируется по названию столбца. Значение счетчика цикла
присваивается столбцу Dep_Id, содержащему идентификатор отдела, а в
столбец Dep_Name с названием отдела помещается литерал Department и
представленный в виде символьной строки номер отдела, равный
значению счетчика цикла. Цикл вставляет новую строку в базовую
таблицу в ходе исполнения метода Обновить (Update) объекта Набор
записей (Recordset).
После того как сценарий вставит 50 строк в таблицу Department,
метод Перейти к первой () перемещает курсор в начало объекта Набор
записей (Recordset). Затем содержимое объекта Набор записей
(Recordset) представляется в виде таблицы HTML, применяя ту же
технику, что и в описанном ранее примере с запросом. На экране 2
показана WEB- страница, которая создается при запуске данной
страницы ASP.
|
Экран 2. Просмотр записей, введенных
на страницу ASP |
Обработка ошибок ASP и ADO
Очень важно перехватывать ошибки, возникающие во время работы
приложения: если вдруг в результате некорректного функционирования
WEB-приложения системой будет сгенерировано сообщение об ошибке, то
работа WEB- приложения будет немедленно прекращена. Для того чтобы
предусмотреть на странице ASP специальную часть сценария VBScript,
отвечающую за обработку возникающих ошибок, применяется оператор On
Error. К сожалению, оператор On Error не обладает всей полнотой
возможностей обработчика ошибок VB, который позволяет перейти в
отдельную секцию кода для обработки информации об ошибке. Оператор
On Error, входящий в VBScript, предоставляет только следующую
альтернативу: либо перейти к следующей операции (Resume Next), либо
вообще отключить обработку ошибок. Этот оператор не дает возможности
перейти к другим секциям кода. Оператор On Error использует
структуру объекта ADO для того, чтобы поместить ошибки, возникающие
во время выполнения WEB-приложения на базе страниц ASP, в коллекцию
объекта ADO Ошибка (Error). Коллекцию ошибок ADO можно обрабатывать
с целью сбора дополнительной информации о том, какие ошибки
встречаются при эксплуатации вашего приложения. Фрагмент кода,
приведенный на листинге 4, показывает, как использовать обработчик
ошибок VBScript и каким образом извлекать информацию из объекта ADO
Ошибка (Error).
Обработку ошибок в листинге 4 обеспечивает оператор On Error.
Затем для создания локального объекта ADO Соединение (Connection) по
сценарию используется объект Соединение (Connection), который
хранился в объекте ASP Сессия (Session). После этого в сценарии
используется метод Выполнить (Execute) объекта ADO Команда (Command)
применительно к заведомо неправильному имени таблицы. Поскольку
обработка ошибок разрешена, программа переходит к следующему
оператору.
Проверка свойства Счетчик (Count) коллекции объектов Ошибка
(Error) позволяет найти ошибки ADO. Если значение счетчика больше
нуля, значит, объект ADO столкнулся с какой- либо ошибкой во время
исполнения. Извлечь информацию об ошибках ADO можно путем
итеративного просмотра коллекции объектов Ошибка (Error). Пример на
листинге 4 использует цикл For Each для обработки элементов
коллекции ошибок объекта ADO Соединение (Connection). Свойства
Номер(), Источник () и Описание () становятся доступными в форме
текстов HTML. Экран 3 представляет страницу с результатами обработки
ошибок. (Обратите внимание на то, что рассмотренный пример является
не более чем демонстрацией подхода. В реальном приложении необходимо
обрабатывать условия возникновения ошибок в коде приложения. При
этом следует избегать вывода ошибок на браузер конечного
пользователя).
|
Экран 3. Обработка ошибок ASP с
помощью ADO |
В том случае, когда на WEB-страницу должны выводиться только
статичные данные, целесообразно применять Мастер WEB-приложений (),
входящий в состав SQL Server. Он поможет легко и быстро
преобразовать информацию базы данных SQL Server к виду WEB-страницы
формата HTML. Если же необходимо создать по-настоящему интерактивное
приложение, способное динамически представлять и обновлять данные,
лучше всего применять комбинацию ASP и ADO, что позволит подключить
вашу базу данных SQL Server к сети WEB. Использование ADO и ASP дает
возможность создавать WEB-приложения, обладающие теми же функциями,
что и их предшественники, выполненные в соответствии с традиционной
архитектурой клиент-сервер.
В основу этой статьи лег адаптированный материал из книги Майкла
Оути и Поля Конте 'Руководство по разработке для SQL Server
7.0'.
Модель объектов ASP
Информационный сервер Интернет, IIS (Internet Information
Server), разработанный корпорацией Microsoft, вводит Активные
серверные страницы, ASP (Active Server Pages), в качестве
автоматического сервера OLE, обладающего иерархической структурой
объекта. На рисунке А представлена модель объекта ASP. Первичным
объектом в программной модели ASP является объект Контекст сценария
(ScriptingContext), который обеспечивает взаимодействие с браузером
клиента. Поскольку объект Контекст сценария (ScriptingContext)
всегда доступен приложениям ASP, то нет необходимости в явном виде
делать на него ссылку. Объект Контекст сценария (ScriptingContext)
содержит шесть основных объектов ASP: пять встроенных объектов и
объект Контекст объекта (ObjectContext). К пяти встроенным объектам
относятся: объект Приложение (Application), объект Запрос (Request),
объект Сервер (Server), объект Сессия (Session) и объект Отклик
(Response).
Все активные WEB-сессии применяют объект Приложение (Application)
для того, чтобы все пользователи могли одновременно обращаться к
информации приложения ASP. Объект Приложение (Application) включает
две коллекции: Содержание (Context) и Статические объекты
(StaticObjects). Каждый объект Содержание (Context) соответствует
какому- либо пункту, для включения которого в WEB-приложение были
использованы команды ActiveX. Коллекция Статические объекты
(StaticObjects) содержит все объекты, для включения которых в
WEB-приложение применялись ярлыки HTML
. Кроме того, объект Приложение (Application) может также содержать
определяемые пользователем объекты, которые были созданы этим
WEB-приложением и предназначены для коллективного применения.
Объект Запрос (Request) получает запросы от клиентов сети WEB.
Объект Запрос (Request) может вместить всю информацию содержащуюся в
форме, плюс сведения о текущем пользователе. Этот объект включает
несколько коллекций, каждая из которых представляет различные
информационные наборы, которые могут возвращаться клиентам WEB в
ответ на их запросы. Каждый объект Сертификат клиента
(ClientCertificate) в одноименной коллекции представляет поле
сертификата, которое возвращает клиент сети WEB и которое в
дальнейшем служит его идентификатором. Коллекция (Cookies) состоит
из элементов, каждый из которых содержит немного информации о
пользователе WEB. Коллекция Формы (Forms) включает набор объектов,
каждый из которых представляет какую-нибудь форму HTML. Коллекция
Строка запроса (QueryString) содержит набор добавляемых аргументов
URL, а коллекция Переменные сервера (ServerVariables) представляет
собой набор переменных, описывающих серверное окружение.
Объект Сервер (Server) применяется для создания объектов OLE,
которые было бы желательно иметь в WEB-приложении. Например, метод
Создать объект (CreateObject) объекта Сервер (Server) генерирует
объекты Соединение (Connection) и Набор записей (Recordset),
обеспечивающих доступ к базам данных SQL Server. Объект Сессия
(Session) поддерживает информацию, относящуюся к текущей сессии в
сети WEB. Объект Сессия (Session) во многом похож на объект
Приложение (Application), но имеет отличие от него. В то время как
объект Приложение (Application) принадлежит всем пользователям сети
WEB, объект Сессия (Session) относится только к текущей сессии.
Коллекция объектов Содержание (Context) объекта Сессия (Session)
включает все пункты, которые добавлялись в WEB-сессию с помощью
команд сценария. Объект Контекст объекта (ObjectContext)
обеспечивает доступ к контексту текущего объекта. Как правило, он
порождает экземпляры объектов MTS или контролирует транзакции базы
данных. Объект Отклик (Response) записывает информацию в виде
потока страниц HTML и отсылает ее в браузер клиента. Объект Отклик
(Response) также поддерживает коллекцию, состоящую из объектов,
содержащих сведения, которые могут быть записаны в систему клиента.
Они в последствии могут быть прочитаны объектом Запрос
(Request).
Литература по ASP
|