Обработка входных данных для метода 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 заголовок на каждый запрос.