Передаём браузеру Hello World!Продолжим конфигурацию, полученную в разделе «Первый запуск». В контейнере создадим объект типа Website: Создадим сайту директорию «/» с действием «запуск функции», название функции «HelloWorld»: В описании созданной директории сайта "Запуск" будет выделено красным цветом, что означает ошибку: Для расшифровки ошибки нужно посмотреть свойства директории: Создадим в контейнере объект типа Scripts: Внутри него создадим файл: Если щёлкнуть по строке с описанием файла, то увидим ошибку, т.к. физически файл ещё не существует: Физически создадим файл в любой программе (я использую Notepad++). Объявляем функцию "HelloWorld с параметром hWorker". Внутри функции осуществляется вывод 'Hello World!' и возврат в регистре eax http кода состояния, в данном случае 200-OK: Код (ASM): HelloWorld proc hWorker:dword echo 'Hello World!'; mov eax,200 HelloWorld endp Теперь, если в браузере обратиться по локальному адресу сервера, будет получен такой ответ: Немного усложним функцию, после вывода 'Hello World!', допишем проверку уровня доступа пользователя запрашивающего страничку и, если уровень отличен от нуля, вывод дополнительного текста на страничку: Код (ASM): mov esi,hWorker; cmp [esi].wstReadAL,0; je exit; echo ' Привет пользователю!' exit: mov eax,200 Полностью это будет выглядеть так (Notepad++): При обновлении странички по локальному адресу сервера, авторизованный пользователь увидит: Очевидно, что браузер отображает страничку не в той кодировке. Для решения этой проблемы нужно добавить мета тэг: Обработчики http запросов получают адрес структуры wst (данные об обрабатываемом запросе текущего воркера) в виде параметра hWorker и адрес для формирования ответа в регистре edi. На выходе регистр edi должен содержать следующий после сформированного ответа адрес, а регистр eax http код ответа. Hello World конфигурация для скачивания, распаковывать в папку с программой. Логин/пароль админа - admin/admin, юзера - 12345/12345.
Динамическое формирование файловПродолжим конфигурацию, полученную в "Hello world!". В начале функции добавим проверки: имя запрашиваемого файла равно 4, расширение запрашиваемого файла равно 3, имя файла равно 'test', расширение файла равно 'bmp'. В случае успеха проверок произведём отключение "вывода скорости обработки запроса и генерации ответа" и приступим к формированию файла, иначе переход на генерацию 'Hello world!': Есть алтернативный способ обнаружения запроса, содержащего 'test.bmp'. Для этого нужно в веб директории создать соответствующиее правило, вызывающее свой обработчик в случае срабатывания, например: Но мы ограничимся одним обработчиком, внутри которого и будет формироваться 'test.bmp'. Для начала нужно сформировать все информационные структуры файла, очистить растр. Выведем в него число '1234567890' у верхнего края, а у нижнего выведем время в тактах, затраченное на обработку запроса и формирование ответа. Кроме этого файлу нужно присвоить MIME тип (в данном случае это 'image/bmp'). Но нужно сохранить значение регистра edi и восстановить перед выходом из обработчика, чтобы воркер сумел корректно определить размер сформированного ответа. Отступим после сформированного ответа на 8192 байт, чтобы воркер мог на этом месте сгенерировать http заголовки ответа. Поместим текст 'image/bmp', а адрес текста передадим в поле wstRespMIMEtype структуры wst, заменив указатель на 'text/html': Добавим запрос 'test.bmp' на основной страничке, обернув изображение в однопиксельную рамку: Посмотрим результат в браузере: Create BMP конфигурация для скачивания, распаковывать в папку с программой. Логин/пароль админа - admin/admin, юзера - 12345/12345.