Обработка входных данных для метода post.

Обработка входных данных для метода get.

Пример: Apache/1.0

Основная информация о взаимодействии клиента и сервера может быть получена из стандартных переменных окружения.

При каждом запуске CGI-сценарий работает так, как будто он прежде никогда не запускался. Программа сценария не переходит в состояние ожидания между отдельными вызовами. Каждый раз процедура инициализации запускается с самого начала. До считывания входных данных необходимо прочесть значение переменной окружения REQUEST_METHOD и определить какую информацию она содержит get или post. Дальнейшие действия зависят от этого значения.

Обработка входных данных зависит от целей написания конкретного сценария. В общем случае обработка данных означает их преобразование.

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

Алгоритм обработки входных данных для метода get состоит из сле­дующих шагов:

1. Определение значения переменной QUERY_STRING.

2. Декодирование имен и их значений. При этом учитывают, что все пробелы были заменены символом "+" и что все символы с десятичным ко­дом больше 128 преобразованы в символ "%" и следующим за ним шестнадцатеричным кодом символа.

3. Формирование структуры «Имя - значение».

Метод get предполагает передачу данных программе через переменные среды.

В переменную QUERY_STRING попадают значения полей форм в формате:

"Имя1=Значение1&Имя2=Значение2&Имя3=Значение3"….

Здесь ИмяN - значения атрибутов NAME, задающих имена управ­ляющих элементов формы. На месте ЗначеииеN сервер записывает то значе­ние атрибута VALUE, которое ввел пользователь в элементе ИмяN. Строку QUERY_STRING обрабатывают обычными функциями языков программирования. Но ее нельзя модифицировать. Эта строка использует кодировку URL.
После декодирования входных данных в массиве строк хранятся все пары имя=значение из входного набора. Этот массив разработчик использует в зависимости от поставленной задачи.

Алгоритм обработки входных данных для метода post состоит из сле­дующих шагов:

1. Определение значения переменной CONTENT_LENGTH.

2. Декодирование имен и их значений. При этом учитывают, что все пробелы были заменены символом "+" и что все символы с десятичным ко­дом больше 128 преобразованы в символ "%" и следующим за ним шестнадцатеричным кодом символа.

3. Формирование структуры «Имя - значение».

Необходимо считать данные из потока STDIN. Если переменная окруже­ния CONTENT_TYPE содержит значение application/x-www-form-urlcoded, данные из потока STDIN также следует декодировать.

Метод post предполагает ввод данных через стандартный поток stdin.

Количество байт, которые следует считывать из STDIN, передается в пе­ременной CONTENT_LENGTH.

Контрольные вопросы

1. Какую информацию содержат переменные среды в интерфейсе CGI?

2. Как производится обработка входных данных для метода get в интерфейсе взаимодействия сервера и внешней программы?

3. Как производится обработка входных данных для метода post в интерфейсе взаимодействия сервера и внешней программы?

4. Каковы этапы работы по обработке входных данных внешней программой?

5. Какую информацию несет заголовок вывода сценария post в интерфейсе взаимодействия сервера и внешней программы?

Лекция 18. Реализация интерфейса информационного взаимодействия программных приложений.Интерфейс взаимодействия внешней программы с сервером.

Рассмотрим интерфейс взаимодействия внешней программы с сервером.

Вывод данных для пользователя

Вне зависимости от метода ввода данных от пользователя, программа CGI направляет свой вывод в стандартный поток STDOUT.

Этот вывод может представлять собой HTML-документ или инструк­ции серверу, где получить необходимый документ. Преимущество последне­го подхода в том, что cgi-модуль не должен формировать полный HTTP за­головок на каждый запрос.