Интернет-сервис "Конструктор сайтов" на основе Zend Framework
Разработка платформы для создания сайтов различной направленности Content Management System на основе Zend Framework. Структура системы, архитектура базы данных. Функции управления контентом и администрирования. Реализация серверной и клиентской частей.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | дипломная работа |
Язык | русский |
Дата добавления | 26.04.2015 |
Размер файла | 3,2 M |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Дипломная работа
Тема: Интернет-сервис "Конструктор сайтов" на основе Zend Framework
Введение
Сегодня уже нет человека, который бы не знал, что такое интернет и как им пользоваться. И всем прекрасно известно, что интернет состоит из миллионов составляющих, так называемых сайтов, интернет проектов, доменов, веб-сайтов, страничек, аккаунтов, блогов и т.д.
Сегодня уже нет компании, которая развивается, не обращая внимания на сетевые технологии, сетевые инструменты на те возможности которые дает интернет. Да и модель развития бизнеса претерпевает изменения. Становления бизнеса теперь уже часто начинается не с аренды офиса, а с создания своего сетевого представительства, корпоративного сайта компании.
Но, несмотря на бурное развитие сетевых технологий, создание даже просто сайта это довольно таки не тривиальная задача и требует от человека серьезных технических знаний.
В компании, в которой я работаю, мы задались целью создать такую систему, которая позволяла бы любому человеку создать свой собственный сайт. При этом мы постарались создать удобный и очень легкий в освоении интерфейс.
Уже существует несколько подобных систем, имеющих свои достоинства и недостатки. В разработке своей системы я попытался учесть и то, и другое, чтобы получить продукт, отвечающий современным тенденциям в веб-программировании и проектировании, а так же, что немаловажно, удовлетворяющий потребностям в быстродействии. На основе этой системы можно будет создавать разнообразные веб-приложения, при этом сведя трудозатраты до минимума и не требующие от человека каких либо навыков в программировании.
На данном этапе сервис уже находится в открытом бета тестировании и каждый может испытать её, для создания своего личного сайта
Сервис предоставляет возможность создать свой собственный одностраничный сайт, не обладая специальными техническими навыками, например: сайт визитку, сайт резюме, личный сайт, семейный сайт, сайт портфолио.
Мы и наша команда старались сфокусировать все свои усилия и добиться преимуществ над другими схожими сервисами.
· Приятный и интуитивно понятный интерфейс для создания сайта.
· Никакой сторонней рекламы на Вашем сайте.
· Вы можете загружать и хранить фотографии без потери качества.
· Сайт будет находиться на Вашем домене. Пример http://www.yourdomain.ru (или любой другой).
· Объем информации которую Вы можете хранить зависит только от тарифного плана Вашего хостинга.
· Сайт загружается вам на FTP в полном объеме.
· Наличие большого кол-ва профессиональных шаблонов.
сайт платформа серверный клиентский
1. Постановка задачи
В дипломной работе требуется реализовать специализированную систему для создания сайтов, содержащую в себе следующие свойства:
1. Software as a service (SaaS) («Программное обеспечение как услуга»), или Software on Demand (SoD) («Программное обеспечение по требованию») -- модель программного обеспечения, при которой поставщик разрабатывает веб-приложение и самостоятельно управляет им, предоставляя заказчикам доступ к программному обеспечению через Интернет. Основное преимущество модели SaaS для потребителя состоит в отсутствии затрат, связанных с установкой, обновлением и поддержкой работоспособности оборудования и программного обеспечения, работающего на нём.
2. Высокая степень надежности и отказоустойчивости, которая обеспечивается многоуровневым кэшированием данных и балансировкой нагрузки на http-серверы.
3. Высокая степень надежности и отказоустойчивости, которая обеспечивается многоуровневым кэшированием данных и балансировкой нагрузки на http-серверы.
4. Удобство использования: интерфейс должен быть продуман с учетом того, что им будет пользоваться человек, далёкий от web-технологий. Интерфейс должен быть простым и интуитивно понятным любому пользователю. А также будет использоваться современные технологии и методы, такие как Jquery UI, WYSIWYG, Drag & Drop interace.
5. Быстродействие: в интерфейсе должна быть использована технология, обеспечивающая обмен данными между браузером клиента и сервером в «фоновом» режиме, без перезагрузки страницы, отличающаяся быстрой отдачей контента и возможностью работы с большими объемами информации.
6. Простота управления: система должна позволять быстро и гибко добавлять различные элементы (блоки) на сайт клиента а также настраивать их.
7. Расширяемость и совместимость: создаваемая система должна быть расширяемой, что позволит легко добавлять туда необходимые блоки с нужным функционалом. В системе должна быть предусмотрена возможность легкого добавления новых типов отдаваемой пользователю информации, нового функционала, быстрого приспособления блоков, уже готовых блоков для каких-то новых нужд, а также иметь возможность быстрого перестроения на другой тип базы данных..
Таким образом, мы получаем, что создаваемый сервис по сути является средой для быстрого создания веб-сайтов. Она должна иметь возможность быстрого приспособления под нужды конкретного проекта в целях экономии времени на его создание.
2. Анализ существующих технологий
При разработке системы для создания и управления интернет-ресурсами использовались следующие технологии и библиотеки:
Клиентские:
• HTML (Hypertext Markup Language - язык разметки гипертекста)
• CSS (Cascading Style Sheets -- каскадные таблицы стилей)
• JavaScript - (скриптовый язык, используемый в браузерах для динамической работы с данными страницы)
• AJAX (Asynchronous JavaScript and XML - Асинхронный JavaScript и XML)
• JSON (JavaScript Object Notation - Объектная нотация JavaScript)
• Jquery Framework (библиотека JavaScript)
• PHP (Hypertext Preprocessor - препроцессор гипертекста)
Далее обо всех этих технологиях будет рассказано несколько подробнее.
HTML
HTML - стандартный язык для разметки документов, используемый во Всемирной Паутине. Все веб-страницы создаются при помощи языка HTML, который интерпретируется браузером и отображается в виде документа, который удобен для восприятия человеком. Язык HTML соответствует международному стандарту ISO 8879.
Текстовые документы, содержащие код на языке HTML (такие документы традиционно имеют расширение «html» или «htm»), обрабатываются специальными приложениями, которые отображают документ в его форматированном виде. Такие приложения, называемые браузерами или интернет-обозревателями, обычно предоставляют пользователю удобный интерфейс для запроса веб-страниц, их просмотра (и вывода на иные внешние устройства), и при необходимости отправки введённых пользователем данных на сервер. Найболее популярными, на сегодняшний день, являются браузеры Internet Explorer, Firefox, Opera и Safari.
Язык HTML был разработан британским учёным Тимом Бернерсом-Ли приблизительно в 1991--1992 годах в стенах Европейского совета по ядерным исследованиям в Женеве (Швейцария). HTML создавался как язык для обмена научной и технической документацией, пригодный для использования людьми, не являющимися специалистами в области вёрстки. HTML успешно справлялся с проблемой сложности SGML путём определения небольшого набора структурных и семантических элементов (размечаемых «тегами»), служащих для создания относительно простых, но красиво оформленных документов. Помимо упрощения структуры документа, в HTML внесена поддержка гипертекста. Мультимедийные возможности были добавлены позже. Изначально язык HTML был задуман и создан как средство структурирования и форматирования документов без их привязки к средствам воспроизведения (отображения). В идеале, текст с разметкой HTML должен был без стилистических и структурных искажений воспроизводиться на оборудовании с различной технической оснащенностью (цветной экран современного компьютера, монохромный экран органайзера, ограниченный по размерам экран мобильного телефона или устройства и программы голосового воспроизведения текстов). Однако современное применение HTML очень далеко от его изначальной задачи. С течением времени, основная идея платформонезависимости языка HTML была отдана в своеобразную жертву современным потребностям в мультимедийном и графическом оформлении.
HTML -- это теговый язык разметки документов. Любой документ на языке HTML представляет собой набор элементов, причём начало и конец каждого элемента обозначается специальными пометками -- тегами. Элементы могут быть пустыми, то есть не содержащими никакого текста и других данных (например, тег перевода строки <br />). В этом случае обычно не указывается закрывающий тег. Кроме того, элементы могут иметь атрибуты, определяющие какие-либо их свойства (например, размер шрифта для элемента font).
Атрибуты указываются в открывающем теге. Вот примеры фрагментов HTML-документа:
• <strong>Текст между двумя тегами -- открывающим и закрывающим.</strong>
• <a href="http://www.example.com">Здесь элемент содержит атрибут href.</a>
• А вот пример пустого элемента: <br>
Каждый HTML-документ, отвечающий спецификации HTML какой-либо версии, должен начинаться со строки объявления версии HTML <!DOCTYPE…>, которая обычно выглядит примерно так:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
Если эта строка не указана, то добиться корректного отображения документа в браузере становится труднее. Далее обозначается начало и конец документа тегами <html> и </html> соответственно. Внутри этих тегов должны находиться теги заголовка (<head></head>) и тела (<body></body>) документа.
XML
XML - язык разметки, фактически представляющий собой свод общих синтаксических правил. XML -- текстовый формат, предназначенный для хранения структурированных данных (взамен существующих файлов баз данных), для обмена информацией между программами, а также для создания на его основе более специализированных языков разметки, иногда называемых словарями.
Целью создания XML было обеспечение совместимости при передаче структурированных данных между разными системами обработки информации, особенно при передаче таких данных через Интернет.
XML -- это иерархическая структура, предназначенная для хранения любого количества текста или любых данных, визуально структура может быть представлена как дерево. Важнейшее обязательное синтаксическое требование -- то, что документ имеет только один корневой элемент (англ. root element) (альтернативно называемый элементом документа (англ. document element)). Это означает, что текст или другие данные всего документа должны быть расположены между единственным начальным корневым тегом и соответствующим ему конечным тегом.
Следующий простейший пример -- правильно построенный документ XML:
<?xml version="1.0"?>
<?xml-stylesheet href="1.xsl" type="text/xml"?>
<list_of_items>
<item id="1">First</item>
<item id="2">Second
<sub_item>Subitem2</sub_item>
</item>
<item id="3">Third</item>
<item id="4">Last</item>
</list_of_items>
В этом простейшем примере видны основные элементы структуры XML-документа. Первая строка XML-документа называется объявлением XML (англ. XML declaration) -- это необязательная строка, указывающая версию стандарта XML (обычно это 1.0), также здесь может быть указана кодировка символов и внешние зависимости. Остальная часть этого XML-документа состоит из вложенных элементов, некоторые из которых имеют атрибуты и содержимое. Элемент обычно состоит из открывающего и закрывающего тегов (меток), обрамляющих текст и другие элементы. Открывающий тег состоит из имени элемента в угловых скобках, например «<step>»; закрывающий тег состоит из того же имени в угловых скобках, но перед именем ещё добавляется косая черта, например «</step>». Содержимым элемента (англ. content) называется всё, что расположено между открывающим и закрывающим тегами, включая текст и другие (вложенные) элементы.
Кроме содержания у элемента могут быть атрибуты -- пары имя-значение, добавляемые в открывающий тег после названия элемента. Значения атрибутов всегда заключаются в кавычки (одинарные или двойные), одно и то же имя атрибута не может встречаться дважды в одном элементе. Не рекомендуется использовать разные типы кавычек для значений атрибутов одного тега.
<car wheels-number="4" doors-count="5" >auto</car>
В приведённом примере у элемента «car» есть два атрибута: «wheels-number», имеющий значение «4», и «doors-count», имеющий значение «5».
XSLT
XSLT - часть спецификации XSL, задающая язык преобразований XML-документов. Спецификация XSLT является рекомендацией W3C.
При применении таблицы стилей XSLT, состоящей из набора шаблонов, к XML-документу (исходное дерево) образуется конечное дерево, которое может быть как XML-структурой, так и обычным текстом. Запросы выбора данных из исходного дерева пишутся на языке запросов XPath.
XSLT находит множество различных применений, в основном в области web-программирования. При разработке платформы язык шаблонов XSLT использовался для преобразования данных, полученных в ходе работы разработанного веб-приложения, в какой-либо другой вид. Например, преобразование XML, полученного в ходе работы приложения, в страницу HTML, удобную для восприятия пользователем (а также ряд других применений, о которых будет рассказано чуть ниже).
Консорциум W3 определяет три составные части языка XSL (от англ. eXtensible Stylesheet Language -- Расширяемый Язык Стилей): XSLT, XPath (язык путей и выражений, используемый в XSLT для доступа к отдельным частям XML-документа) и XSL Formatting Objects -- словарь, определяющий семантику форматирования документов.
Для примера рассмотрим XSLT-преобразование уже приведённого выше в пример XML-документа:
<?xml version="1.0"?>
<?xml-stylesheet href="1.xsl" type="text/xml"?>
<list_of_items>
<item id="1">First</item>
<item id="2">Second
<sub_item>Subitem2</sub_item>
</item>
<item id="3">Third</item>
<item id="4">Last</item>
</list_of_items>
Применим к нему следующий стиль для XSLT-трансформации:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" indent="yes"/>
<xsl:template match="/">
<html>
<head></head>
<body>
<xsl:apply-templates select="list_of_items/item"/>
</body>
</html>
</xsl:template>
<xsl:template match="list_of_items/item">
<xsl:value-of select="@id"/> : <xsl:value-of select="."/> <br />
</xsl:template>
</xsl:stylesheet>
В результате на экран браузера будет выведена следующая информация:
1: First
2: Second Subitem2
3: Third
4: Last
Данный пример позволяет понять, что использование XSLT в качестве шаблонизатора и средства обработки XML-документов позволяет разделить два процесса: непосредственный процесс обработки данных на сервере и процесс обработки этих данных для удобного отображения их пользователю.
Действия по преобразованию одного XML-документа в другой выполняются специальной программой - XSLT-процессором, которая получает на входе XML-документ, таблицу стилей XSLT, а на выходе выдает документ, полученный при применении XSLT-преобразований ко входному XML-документу.
PHP
PHP -- скриптовый язык программирования, созданный для генерации HTML-страниц на веб-сервере и работы с базами данных. В настоящее время поддерживается подавляющим большинством хостинг-провайдеров. Входит в LAMP -- «стандартный» набор для создания веб-сайтов (Linux, Apache, MySQL, PHP (Python или Perl)).
В области программирования для Сети PHP -- один из популярнейших скриптовых языков (наряду с JSP, Perl и языками, используемыми в ASP.NET) благодаря своей простоте, скорости выполнения, богатой функциональности и распространению исходных кодов на основе лицензии PHP. PHP отличается наличием ядра и подключаемых модулей, «расширений»: для работы с базами данных, сокетами, динамической графикой, криптографическими библиотеками, документами формата PDF и т. п. Любой желающий может разработать своё собственное расширение и подключить его. Существуют сотни расширений, однако в стандартную поставку входит лишь несколько десятков хорошо зарекомендовавших себя. Интерпретатор PHP подключается к веб-серверу либо через модуль, созданный специально для этого сервера (например, для Apache или IIS), либо в качестве CGI-приложения.
Кроме этого, он может использоваться для решения административных задач в операционных системах UNIX, GNU/Linux, Microsoft Windows, Mac OS X и AmigaOS. Однако в таком качестве он не получил распространение, отдавая пальму первенства Perl, Python и VBScript.
Синтаксис PHP подобен синтаксису языка Си. Некоторые элементы, такие как ассоциативные массивы и цикл foreach, заимствованы из Perl.
Ныне PHP используется сотнями тысяч разработчиков. Несколько миллионов сайтов сообщают о работе с PHP, что составляет более пятой доли доменов Интернета.
При разработке платформы нами был выбран этот язык не случайно. У него есть рад преимуществ перед другими языками, а именно:
• Традиционность. Синтаксис PHP очень похож на синтаксис многих языков, используемых в самых различных областях. Некоторые конструкции позаимствованы из языка С, Perl.
• Эффективность. «Движок» PHP не является ни компилятором, ни интерпретатором. Он является транслирующим интерпретатором. Такое устройство «движка» PHP позволяет обрабатывать сценарии с достаточно высокой скоростью. Производительность движка PHP вполне достаточна для создания серьезных web-приложений.
• Безопасность. В РНР реализованы механизмы безопасности, находящиеся под управлением администраторов; при правильной настройке РНР это обеспечивает максимальную свободу действий и безопасность. РНР может работать в так называемом безопасном режиме (safe mode), который ограничивает возможности применения РНР пользователями по ряду важных показателей. Например, можно ограничить максимальное время выполнения и использование памяти (неконтролируемый расход памяти отрицательно влияет на быстродействие сервера). По аналогии с cgi-bin администратор также может устанавливать ограничения на каталоги, в которых пользователь может просматривать и исполнять сценарии РНР, а также использовать сценарии РНР для просмотра конфиденциальной информации на сервере (например, файла passwd). В стандартный набор функций РНР входит ряд надежных механизмов шифрования. РНР также совместим с многими приложениями независимых фирм, что позволяет легко интегрировать его с защищенными технологиями электронной коммерции (e-commerce). Другое преимущество заключается в том, что исходный текст сценариев РНР нельзя просмотреть в браузере, поскольку сценарий компилируется до его отправки по запросу пользователя. Реализация РНР на стороне сервера предотвращает похищение нетривиальных сценариев пользователями, знаний которых хватает хотя бы для выполнения команды View Source.
• Гибкость. PHP является платформенно-независимым языком и не содержит каких-либо функций или методов, работающих только на определенных типов web-серверов. Также средства PHP позволяют программисту работать с внешними компонентами, такими как, например, Enterprise Java Beans.
• Бесплатность. PHP - полностью open source язык.
• При создании платформы было решено использовать PHP версии 5, поскольку в ней были полностью переработаны функции ООП, которые стали во многом схожи с моделью, используемой в Java. В частности, введён деструктор, открытые, закрытые и защищённые члены и методы, окончательные члены и методы, интерфейсы и клонирование объектов.
JavaScript
JavaScript -- скриптовый язык, чаще всего использующийся при создании сценариев поведения браузера, встраиваемых в веб-страницы. JavaScript в настоящее время полностью занимает нишу браузерных языков.
JavaScript обладает рядом свойств объектно-ориентированного языка, но благодаря прототипированию поддержка объектов в нём отличается от традиционных ОО языков. Кроме того, JavaScript имеет ряд свойств, присущих функциональным языкам -- функции как объекты первого уровня, объекты как списки, карринг (currying), анонимные функции, замыкания (closures) -- что придаёт языку дополнительную гибкость.
JavaScript имеет C-подобный синтаксис, но по сравнению с языком Си имеет следующие коренные отличия:
* объекты, с возможностью интроспекции и динамического изменения типа через механизм прототипов
* функции как объекты первого класса
* обработка исключений
* автоматическое приведение типов
* автоматическая сборка мусора
* анонимные функции
Пример кода на JavaScript:
function MyFunc()
{
this.a = 1;
this.b = 2;
}
var mc = new MyFunc();
mc.a = mc.b * 2;
Одна из популярных технологий, позволившая сделать страницы более динамическими и обеспечить новые возможности -- это динамическая загрузка и вставка данных в документ, получившая название AJAX.
AJAX
AJAX (от англ. Asynchronous JavaScript and XML -- «асинхронный JavaScript и XML») -- это подход к построению интерактивных пользовательских интерфейсов веб-приложений, заключающийся в «фоновом» обмене данными браузера с веб-сервером. В результате при обновлении данных веб-страница не перезагружается полностью, и веб-приложения могут быть сделаны более быстрыми и удобными.
AJAX - концепция использования нескольких смежных технологий:
* использование технологии динамического обращения к серверу «на лету», без перезагрузки всей страницы полностью
* использование DHTML для динамического изменения параметров страницы
В качестве формата передачи данных обычно используются JSON (о нем речь пойдет чуть ниже) или XML (о нем было рассказано выше).
Почему AJAX был выбран как один из инструментов, используемый при проектировании системы? Потому, что его использование позволяет избежать проблем с продолжительным временем загрузки данных, характерную для большинства продуктов подобного рода.
Преимущества технологии AJAX более подробно описаны далее:
* Экономия трафика. Использование AJAX позволяет значительно, сократить трафик при работе с веб-приложением, благодаря тому, что часто вместо загрузки всей страницы достаточно, загрузить только небольшую изменившуюся часть.
* Уменьшение нагрузки на сервер. AJAX позволяет несколько снизить нагрузку на сервер, к примеру, в Gmail когда вы отмечаете прочитанные письма, серверу достаточно внести изменения в базу данных и отправить клиентскому скрипту сообщение об успешном выполнении операции, вместо необходимости повторно создавать страницу и отсылать ее клиенту.
* Увеличение реакции интерфейса. Поскольку нужно загрузить только изменившуюся часть, то пользователь видит результат своих действий быстрее.
JSON
JSON (англ. JavaScript Object Notation) -- текстовый формат обмена данными, основанный на JavaScript и обычно используемый именно с этим языком. Как и многие другие текстовые форматы, JSON легко читается людьми.
Несмотря на происхождение от JavaScript (точнее, от подмножества языка стандарта ECMA-262 1999 года), формат считается языконезависимым и может использоваться практически с любым языком программирования. Для многих языков существует готовый код для создания и обработки данных в формате JSON.
Практическая польза использования JSON открывается при использовании технологии AJAX. Формат JSON является более кратким и удобочитаемым по сравнению с XML, является «родным» для Javascript. Кроме того, в JSON код возможна вставка вполне работоспособных функций.
JSON строится на двух структурах:
* Набор пар имя/значение. В различных языках это реализовано как объект, запись, структура, словарь, хеш-таблица, список с ключом или ассоциативный массив.
* Пронумерованный набор значений. Во многих языках это реализовано как массив, вектор, список, или последовательность.
Это - универсальные структуры данных. Теоретически, все современные языки программирования поддерживают их в той или другой форме. Так как JSON используется для обмена данными между различными языками программирования, то имеет смысл строить его на этих структурах.
В JSON используются их следующие формы:
* Объект -- это неупорядоченное множество пар имя/значение, заключенное в фигурные скобки { }. Между именем и значением стоит символ :, а пары имя/значение разделяются запятыми.
* Массив (одномерный) -- это множество значений, имеющих порядковые номера (индексы). Массив заключается в квадратные скобки [ ]. Значения отделяются запятыми.
* Значение может быть строкой в двойных кавычках, или числом, или true, или false, или null, или объектом, или массивом. Эти структуры могут быть вложены друг в друга.
* Строка -- это упорядоченное множество из нуля или более символов юникода, заключенное в двойные кавычки, с использованием escape-последовательностей начинающихся с обратной косой черты (backslash). Символы представляются простой строкой.
WDDX
WDDX -- (англ. Web Distributed Data eXchange -- обмен данными распределенными во Всемирной паутине) -- механизм обмена данными в гетерогенной среде, независящий от языка программирования, платформы и способа транспортировки. Представляет из себя спецификацию определенного формата XML 1.0 DTD и имеет множество интерфейсов (библиотек) в большинстве современных языков программирования.
WDDX поддерживает примитивные типы данных, такие как целые и вещественные числа, строки и булевые значения, а также более сложные -- структуры, множества и другие.
Формат был разработан в 1998 году Симеоном Симеонвым в фирме Allaire Corporation.
Данный формат может быть использован для сериализации данных в и удобства их дальнейшей обработки. Например, код скрипта на сервере обрабатывает данные, которые затем сериализуются в WDDX и далее обрабатываются при помощи XSLT-процессора для придания этим данным нормального для человеческого восприятия вида (для получения HTML-страницы, отображаемой в браузере, например).
Для примера приведу вид WDDX структуры:
<?xml version="1.0" encoding="UTF-8"?>
<wddxPacket version='1.0'>
<header comment='PHP'/>
<data>
<struct>
<var name='pi'>
<number>3.1415926</number>
</var>
<var name='cities'>
<array length='3'>
<string>Москва</string>
<string>Киев</string>
<string>Минск</string>
</array>
</var>
</struct>
</data>
</wddxPacket>
MYSQL
Также нельзя не упомянуть одну из наиболее популярных свободнаых систем управления базами данных - MySQL. MySQL является собственностью компании MySQL AB, осуществляющей разработку и поддержку приложения. Распространяется под GNU General Public License и под собственной коммерческой лицензией, на выбор. Помимо этого компания MySQL AB разрабатывает функциональность по заказу лицензионных пользователей, именно благодаря такому заказу почти в самых ранних версиях появился механизм репликации.
MySQL является решением для малых и средних приложений. Входит в LAMP. Обычно MySQL используется в качестве сервера, к которому обращаются локальные или удалённые клиенты, однако в дистрибутив входит библиотека внутреннего сервера, позволяющая включать MySQL в автономные программы.
Гибкость СУБД MySQL обеспечивается поддержкой большого количества типов таблиц: пользователи могут выбрать как таблицы типа MyISAM, поддерживающие полнотекстовый поиск, так и таблицы InnoDB, поддерживающие транзакции на уровне отдельных записей. Более того, СУБД MySQL поставляется со специальным типом таблиц EXAMPLE, демонстрирующим принципы создания новых типов таблиц. Благодаря открытой архитектуре и GPL-лицензированию, в СУБД MySQL постоянно появляются новые типы таблиц.
3. Спецификация системы
В этом разделе будет рассказано о том, какие технологии в проектировании были использованы при создании системы
.Для эффективного решения задач проектирования сложных систем (таких, как и разрабатываемая система) существуют так называемые шаблоны (паттерны) проектирования, цель которых - по другому взглянуть на объектно-ориентированное программирование и его основные положения применительно к решаемой задаче.
Любой паттерн проектирования, используемый при разработке информационных систем, представляет собой формализованное описание часто встречающейся задачи проектирования, удачное решение данной задачи, а также рекомендации по применению этого решения в различных ситуациях. Кроме того, паттерн проектирования обязательно имеет общеупотребимое наименование. Правильно сформулированный паттерн проектирования позволяет, отыскав однажды удачное решение, пользоваться им снова и снова. Следует подчеркнуть, что важным начальным этапом при работе с паттернами является адекватное моделирование рассматриваемой предметной области. Это является необходимым как для получения должным образом формализованной постановки задачи, так и для выбора подходящих паттернов проектирования.
Сообразное использование паттернов проектирования дает разработчику ряд неоспоримых преимуществ. Приведем некоторые из них. Модель системы, построенная в терминах паттернов проектирования, фактически является структурированным выделением тех элементов и связей, которые значимы при решении поставленной задачи. Помимо этого, модель, построенная с использованием паттернов проектирования, более проста и наглядна в изучении, чем стандартная модель. Тем не менее, несмотря на простоту и наглядность, она позволяет глубоко и всесторонне проработать архитектуру разрабатываемой системы с использованием специального языка. Применение паттернов проектирования повышает устойчивость системы к изменению требований и упрощает неизбежную последующую доработку системы. Кроме того, трудно переоценить роль использования паттернов при интеграции информационных систем организации. Также следует упомянуть, что совокупность паттернов проектирования, по сути, представляет собой единый словарь проектирования, который, будучи унифицированным средством, незаменим для общения разработчиков друг другом.
Поскольку одной из целей работы является разработка платформы, которая может в дальнейшем легко изменяться и дополняться, был применен паттерн проектирования MVC.
MVC
Model-view-controller (MVC, «Модель-представление-поведение») -- архитектура программного обеспечения, в которой модель данных приложения, пользовательский интерфейс и управляющая логика разделены на три отдельных компонента, так, что модификация одного из компонентов оказывает минимальное воздействие на другие компоненты.
Шаблон MVC позволяет разделить данные, представление и обработку действий пользователя на три отдельных компонента
• Модель (Model). Модель предоставляет данные (обычно для View), а также реагирует на запросы (обычно от контролера), изменяя свое состояние.
• Представление (View). Отвечает за отображение информации (пользовательский интерфейс).
• Поведение (Controller). Интерпретирует данные, введенные пользователем, и информирует модель и представление о необходимости соответствующей реакции.
Важно отметить, что как представление, так и поведение зависят от модели. Однако модель не зависит ни от представления, ни от поведения. Это одно из ключевых достоинств подобного разделения. Оно позволяет строить модель независимо от визуального представления.
Рисунок 1 Model-View-Controller
Применительно к интернет-приложениям бытует мнение, что части контроллер и представление объединены, потому что за отображение и одновременно за ввод информации отвечает браузер. С этим можно согласиться, но в этом случае мы потеряем одно очень важное преимущество: нельзя будет отделить алгоритмы обработки данных от алгоритмов их представления, что существенным образом скажется на расширяемости создаваемой системы. Об этом будет рассказано чуть ниже.
Диаграмма работы MVC-системы
Описанные выше положения определяют примерную структуру системы в соответствии с использованием паттерна программирования MVC. Комментарии по дальнейшей разработке системы описаны в следующей главе.
Ниже приведена диаграмма работы MVC-системы. Диаграмма работы создаваемой системы будет немного сложнее, но по ключевым моментам будет очень похожа на приведенную ниже:
Рисунок 2 Работа MVC-системы
Mod_rewrite
Одним из ключевых моментов в спецификации разрабатываемой системы является то, что выполнение тех или иных функций осуществляется в зависимости от запрошенного пользователем адреса (URL, введенного в браузере). Система имеет одну точку входа - файл index.php, на который должны перенаправляться все запросы пользователя. В нем должен создаваться основной объект, управляющий работой системы, анализируя введенный пользователем URL. Для этого используется модуль сервера Apache под названием mod_rewrite.
Этот модуль использует механизм основанный на правилах (синтаксический анализатор основанный на регулярных выражениях) для преобразований запрошенных URL на лету. Он поддерживает неограниченное количество правил и неограниченное количество связанных с правилом условий для реализации действительно гибкого и мощного механизма для URL преобразований. URL преобразования могут зависеть от разных критериев, например переменных сервера, переменных окружения, HTTP заголовков, времени и даже запросы к внешним базам данных в разных форматах могут быть использованы для достижения действительно точного соответствия преобразованных URL вашим ожиданиям.
Настройка модуля для разрабатываемой системы будет выглядеть примерно следующим образом:
SetEnv APPLICATION_ENV development
php_flag magic_quotes_gpc Off
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} -s [OR]
RewriteCond %{REQUEST_FILENAME} -l [OR]
RewriteCond %{REQUEST_FILENAME} -d
RewriteRule ^.*$ - [NC,L]
RewriteRule ^.*$ /index.php [NC,L]
Сперва мы проверяем, существует ли запрашиваемый файл, используя директиву RewriteCond, и, если нет, то перенаправляем запрос на index.php. Такая проверка на существование файла необходима, так как иначе index.php будет пытаться обрабатывать все запросы к сайту, включая запросы на изображения. А это нам как раз и не надо.
Таким образом, в корневой директории сервера будет находиться файл .htaccess (файл конфигурации Apache-сервера, в котором прописаны настройки для модуля mod-rewrite) и файл index.php, в который является точкой входа в приложении и создаёт объект Application, управляющий дальнейшей работой приложения.
Zend Framework
Разрабатывать систему было решено на Zend фреймворке, так как это позволило добиться колоссальных сокращений сроков разработки требуемой системы.
Zend Framework -- это свободный фреймворк на PHP для разработки веб-приложений и веб-сервисов.
Фреймворк пытается следовать духу PHP, предоставляет простые интерфейсы и мощную функциональность для разработки приложений. Он предоставляет расширения для построения современных, быстрых и безопасных систем.
Основывается на идеях MVC. Разрабатывается компанией Zend, являющейся разработчиком самого PHP.
Помимо MVC-компонентов Zend Framework содержит множество библиотек, полезных для построения приложения. Также есть компоненты для интеграции со сторонними сервисами -- например, YouTube, del.icio.us и многими другими. Начиная с версии 1.6 поставляется с JavaScript фреймворком Dojo, а так же включает в себя компоненты для работы с ним.
Существует и другие фреймворки CakePHP, Symfony, CodeIgniter, но ZendFramework на наш взгляд стал лидером как заслуживший признание временем.
Jquery
С клиентской стороны было решено использовать JavaScript библиотеку Jquery, фокусирующуюся на взаимодействии JavaScript и HTML. Библиотека jQuery помогает легко получать доступ к любому элементу DOM, обращаться к атрибутам и содержимому элементов DOM, манипулировать ими. Также библиотека jQuery предоставляет удобный API по работе с Ajax.
Возможности
• Переход по дереву DOM, включая поддержку XPath как плагина;
• Реализовано простая работа с событиями;
• Эффектные визуальные эффекты;
• AJAX-дополнения;
• Наличие огромного кол-ва JavaScript-плагинов.
• Решена проблема «кроссбраузерности»
Также главным расширение для Jquery используемым в нашей системы стал JQuery UI это открытая библиотека, содержащая компоненты интерфейса. С помощью которой удалось создать очень достойный интерфейс. Наполненный различными визуальными эффектами.
4. Разработка структуры системы
По сути система представляет из себя двухстраничный сайт
Рисунок 3 Главная страница проекта.
Страничку проекта - главная страница нашей системы на которой пользователь мог узнать основную информацию о системе
Рисунок 4 Страница создания сайта.
Страничку создания своего сайта - на которой пользователь может создать свой одностраничный (на данный момент) сайт.
Архитектура базы данных
Для нашего проекта была создана следующая структура базы данных:
Таблица Users
Представляет собой пользователей нашей системы
Таблица Sites
Содержит в себе информацию о созданных сайтах в системе
Таблица Blocks
Блоки это структурные единицы, из которых формируются страницы сайта
Таблица Widgets
Содержит в себе типы блоков.
Таблица Vault13
Содержит в себе информацию о загруженных файлах на сайтах пользователей
Построение структуры нашего проекта, было очень жестко завязано на рекомендация которые предоставляет Zend framework. Была использована следующая структура каталогов проекта.
1. Snail_Project
2. |-- application
3. | |-- Bootstrap.php
4. | |-- configs
5. | | `-- application.ini
6. | |-- controllers
7. | | |-- ErrorController.php
8. | | |-- ExportController.php
9. | | |-- SnailController.php
10. | | |-- StatController.php
11. | | `-- IndexController.php
12. | |-- models
13. | | |-- Supermodel.php
14. | | `-- Statmodel.php
15. | `-- views
16. | |-- helpers
17. | `-- scripts
18. | |-- snail
19. | | `-- error.phtml
20. | |-- error
21. | | `-- error.phtml
22. | `-- index
23. | `-- index.phtml
24. |-- library
25. | `-- zend
26. |-- public
27. | |-- CSS
28. | |-- JS
29. | `-- index.php
30. `-- tests
31. |-- application
32. | `-- bootstrap.php
33. |-- library
34. | `-- bootstrap.php
35. `-- phpunit.xml
Из данной структуры мы сразу видим основные каталоги и что в них находится.
И так по порядку
1. snail_project - основной каталог проекта в котором находятся абсолютно все файлы проекта.
2. application - директория в которой находятся все основные скрипты нашего проекта. Как видим большинство скриптов вынесено из публичной директории проекта, что очень важно для безопасности. Zend Framework основывается на MVC. Аббревиатура MVC - сокращение от » Model-View-Controller (модель-вид-контроллер), это паттерн проектирования, предназначенный для отделения логики приложения от логики представления. Следовательно мы видим директории для основных компонентов системы.
1. config - директория в которой находятся конфигурационные файлы
2. controllers - директория в которой будут находится все классы контролеров (controllers). Контролеры исполняют различные функции. Если кратко то они получают запрос на выполнение какой-либо функции, анализируют его, запрашивают данные из моделей, обрабатывают полученные данные и передают их в представления, которые в свою очередь являются ответом клиенту.
3. models - класс выполняющие роль посредника между контроллером и СУБД.
4. view - тут находятся шаблоны.
3. library - директория в которой находятся различные подключаемые библиотеки
4. public - публичная папка, к которой есть доступ из вне. Содержащая в себе только один файл с расширением index.php на который приходят все запросы.
1. JS - директория с клиентскими скриптами
2. CSS - стили
5. test - директория для тестов
MVC & Zend Framework
Обычно PHP-приложение выглядит следующим образом:
<?php
include "common-libs.php";
include "config.php";
mysql_connect($hostname, $username, $password);
mysql_select_db($database);
?>
<?php include "header.php"; ?>
<h1>Home Page</h1>
<?php
$sql = "SELECT * FROM news";
$result = mysql_query($sql);
?>
<table>
<?php
while ($row = mysql_fetch_assoc($result)) {
?>
<tr>
<td><?php echo $row['date_created']; ?></td>
<td><?php echo $row['title']; ?></td>
</tr>
<?php
}
?>
</table>
<?php include "footer.php";
?>
В течение всего жизненного цикла приложения такого типа оно становится немасштабируемым и содержит множество уязвимостей во множестве мест.
Одним из способов повышения масштабируемости приложения является разделение кода на три части (обычно в отдельных файлах):
Модель
Модель - часть приложения, которая работает с данными, предназначенными для вывода. В приведённом выше примере это получение новостей. Таким образом, модель реализует бизнес-логику приложения и берёт на себя работу с БД.
Вид
Скрипты вида состоят из частей приложения, которые должны быть выведены на экран. Обычно, это HTML-код.
Контроллер
Контроллер объединяет вместе модель и вид, определяя, какие именно скрипты модели и вида должны быть задействованы.
Zend Framework (ZF) использует архитектуру Model-View-Controller. Это подразумевает разделение разных частей приложения, облегчая разработку и масштабирование приложения.
В тоже время ZF является компонентным Фреймворком и за каждую функциональность отвечает своей компонент.
За представление MVC отвечают следующие компоненты
· Zend_Application, Zend_Application_Bootstrap, Zend_Application_Module, Zend_Application_Resource
· Zend_Controller_Front, Zend_Controller_Action, Zend_Controller_Dispatcher, Zend_Controller_Plugin, Zend_Controller_Router
· Zend_Form
· Zend_Layout, Zend_View, Zend_View_Filter, Zend_View_Helper
Далее в следующей главе по мере реализации нашей системы мы познакомимся со всеми основными компонентами ZF.
5. Реализация системы
В данной главе будет описано как реализовывалась наша система с самого её зарождения. По ходу изложения мы будем сталкиваться с использованием каких либо компонент ZF и будет приводиться краткое описание работы данного компонента.
Реализация серверной части
Реализация нашей системы да и любой другой построенной на основе Zend Framework начинается с получения самой библиотеки, которую можно в любой момент скачать с официального сайта компании Zend.
ZF налагает некоторые требования на окружение в котором будет в дальнейшем работать наша система.
Требуется
· PHP 5.1.4 (или выше)
· Поддержка веб-сервером функционала mod_rewrite
Далее получить необходимую структуру каталогов можно с помощью консольного инструмента zf.bat который находится в скачиваемом архиве вместе с ZF
C помощью команды
C:> zf.bat create project snail_project
В своем веб-сервере установите директорию public из приведенной выше структуры в качестве корневой для веб-документов.
Если все правильно установлено то вы получаете готовую рабочую страничку находящуюся по адресу в нашем случае это был
http://fastsite.majordomo.ru
В полученной директории есть несколько основных файлов а именно
Index.php
<?php
// Подключение библиотеки ZF
set_include_path(implode(PATH_SEPARATOR, array(
realpath(dirname(__FILE__) . '/../library'),
get_include_path(),
)));
// Определение пути к директории приложения
defined('APPLICATION_PATH')
|| define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/application'));
// Определяем application environment
defined('APPLICATION_ENV')
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
/**Поключаем компонент Zend_Application */
require_once 'Zend/Application.php';
// Создаем application, bootstrap, и запускаем
$application = new Zend_Application(
APPLICATION_ENV,
APPLICATION_PATH . '/configs/application.ini'
);
$application->bootstrap();
$application->run();
Zend_Application
Представляет собой средство для начальной загрузки, предоставляющее повторно используемые ресурсы, общие и связанные с модулями загрузочные классы, проверку зависимостей. Он также обеспечивает установку режима работы PHP и вводит автозагрузку по умолчанию.
Zend_Application представляет собой средство для начальной загрузки, предоставляющее повторно используемые ресурсы, общие и связанные с модулями загрузочные классы, проверку зависимостей. Он также обеспечиваПолучение сконфигурированного MVC-приложения, готового к обработке запроса, требует наличия дополнительного кода, объем которого зависит от используемого функционала: установка соединения с базой данных, конфигурирование видов и их помощников, конфигурирование макетов (layouts), регистрация плагинов, регистрация помощников действий и так далее.
Кроме того, вы можете захотеть повторно использовать один и тот же код для загрузки тестов, сервисных скриптов, скриптов, предназначенных для запуска через крон. Можно просто добавлять свой скрипт загрузки, но часто встречаются инициализации, зависящие от окружения - например, для запуска через крон MVC может быть лишним, а для сервисного скрипта может быть достаточно только слоя баз данных.
Zend_Application облегчает управление начальной загрузкой и способствует повторному использованию путем инкапсуляции загрузки в соответствии с парадигмой ООП.
Zend_Application состоит из трех областей:
Zend_Application: загружает окружение PHP, включая include_paths и автозагрузку (autoloading), инстанцирует запрошенный загрузочный класс.
Zend_Application_Bootstrap: предоставляет интерфейсы для загрузочных классов. Zend_Application_Bootstrap_Bootstrap предоставляет общий функционал, удовлетворяющий большинство нужд по начальной загрузке, включающие в себя алгоритмы проверки зависимостей и возможность загрузки ресурсов по требованию.
Zend_Application_Resource предоставляет интерфейс для стандартных ресурсов загрузки, которые могут быть загружены по требованию через экземпляр загрузочного класса, и несколько реализаций ресурсов, используемых по умолчанию.
Разработчики могут создавать загрузочный класс для приложения, расширяя Zend_Application_Bootstrap_Bootstrap или, как минимум, реализуя интерфейс Zend_Application_Bootstrap_Bootstrapper. Входная точка (например, public/index.php) будет загружать Zend_Application и инстанцировать его путем передачи:
Текущего окружения
Опций для загрузки
Опции загрузки включают в себя путь к файлу, содержащему в себе загрузочный класс и, опционально:
Любые дополнительные пути для добавления в include_path
Любые дополнительные пространства имен автозагрузки, которые требуется зарегистрировать
Любые установки php.ini для инициализации
Имя класса загрузки (если используется имя, отличное от "Bootstrap")
Пары префикс-путь для ресурсов
Любые ресурсы для использования (указываются через имя класса или их короткое имя)
Дополнительный путь к загружаемому конфигурационному файлу
Дополнительные опции конфигурации
Опции могут быть массивом, объектом Zend_Config или путью к конфигурационному файлут установку режима работы PHP и вводит автозагрузку по умолчанию.
Далее управление предается
Zend_Controller
Zend_Controller является ядром системы MVC в Zend Framework. Аббревиатура MVC - сокращение от » Model-View-Controller (модель-вид-контроллер), это паттерн проектирования, предназначенный для отделения логики приложения от логики представления. Zend_Controller_Front реализует паттерн » Front Controller, в котором все запросы перехватываются фронт-контроллером (front controller) и перенаправляются отдельным контроллерам действий (action controllers), выбор которых производится по запрошенному URL.
Система Zend_Controller построена с расчетом на расширяемость как через наследование от уже существующих классов и написание новых классов, реализующих различные интерфейсы и абстрактные классы, образующих основу семейства классов контроллеров, так и через написание плагинов или помощников действий для наращивания функциональности системы или управления ею.
Zend_Layout
Zend_Layout реализует классический паттерн "двухэтапное представление" (Two Step View pattern), который позволяет разработчикам помещать содержимое приложения в другой вид, который обычно представляет собой шаблон сайта. Такие шаблоны в других проектах обычно называются макетами, и Zend Framework использует этот термин во избежание противоречий.
Основными задачами Zend_Layout являются:
Автоматический выбор и рендеринг макетов при использовании компонент MVC Zend Framework-а.
Обеспечение отдельной области видимости для связанных с макетом переменных и содержимого.
Предоставление конфигурации, включающей в себя имя макета, определение скрипта макета (инфлекция) и путь к скрипту макета.
Возможность отключения макетов, изменения скриптов макетов и других состояний; возможность производить эти действия в контроллерах действий и скриптах вида.
Следование тем же правилам по определению скрипта вида (инфлекции), что и ViewRenderer, но с возможностью использования других правил.
Возможность использования без компонент MVC Zend Framework-а.
Zend_View
Zend_View является классом для работы с частью вид (view) паттерна модель-вид-контроллер (model-view-controller). То есть он предназначен для того, чтобы помочь отделить скрипты видов от скриптов моделей и контроллеров. Он предоставляет систему помощников, фильтрации вывода и экранирования переменных.
Zend_View не зависит от выбранной вами системы шаблонов - вы можете использовать PHP в качестве языка шаблонов или создавать экземпляры других систем шаблонов и работать с ними в ваших скриптах вида.
По существу применение Zend_View состоит из двух шагов: 1. Ваш скрипт контроллера создает экземпляр Zend_View и объявляет переменные этого экземпляра. 2. Контроллер приказывает Zend_View воспроизвести данный вид, посредством этого производится контроль за скриптом вида, который генерирует выходные данные вида.
Скрипт контроллера
В качестве простого примера предположим, что ваш контроллер имеет список данных по книгам, который нужно воспроизвести через вид. Скрипт контроллера может выглядеть наподобие этого:
// использование модели для получения данных о заголовках и авторах книг
$data = array(
array(
'author' => 'Hernando de Soto',
'title' => 'The Mystery of Capitalism'
),
array(
'author' => 'Henry Hazlitt',
'title' => 'Economics in One Lesson'
),
array(
'author' => 'Milton Friedman',
'title' => 'Free to Choose'
)
);
// теперь присваиваем данные по книгам экземпляру Zend_View
Zend_Loader::loadClass('Zend_View');
$view = new Zend_View();
$view->books = $data;
// и выполняем скрипт вида "booklist.php"
echo $view->render('booklist.php');
Скрипт вида
Теперь нам нужен сопутствующий скрипт вида "booklist.php". Это такой же скрипт PHP, как и остальные, за одним исключением: он выполняется в области видимости экземпляра Zend_View, это означает, что $this ссылается на экземпляр Zend_View. Переменные, присваиваемые в контроллере для скрипта вида, являются открытыми свойствами экземпляра Zend_View. Таким образом, базовый скрипт вида может выглядеть следующим образом:
<?php if ($this->books): ?>
<!-- Таблица из нескольких книг. -->
<table>
<tr>
<th>Author</th>
<th>Title</th>
</tr>
<?php foreach ($this->books as $key => $val): ?>
...Подобные документы
Работа с компонентами в Zend Framework. Структура директорий, модели, представления, контроллеры, модули, маршруты. Взаимодействие между компонентами. Работа с формами и моделями объектно-ориентированного фреймворка. Паттерн Data Mapper, особенности.
курсовая работа [600,8 K], добавлен 12.01.2016Развитие Internet и новых способов общения между людьми. Система управления сайтом Content Manager System. Процесс создания, редактирования и оформления сайтов. Возможность создания различных по правам доступа частей сайта. Критерии выбора CMS.
реферат [35,5 K], добавлен 03.04.2011Обзор существующих технологий разработки программного обеспечения. Описание платформы NET Framework. Принцип работы платформы: компиляция исходного кода; процесс загрузки и исполнения кода; IL-код и верификация. Новые возможности платформы NET Framework.
реферат [30,7 K], добавлен 01.03.2011Анализ средств формирования рейтинга Интернет-сайтов. Критерии оценки веб-сайтов при проведении Интернет-конкурса. Выбор браузера и разработка архитектуры плагина. Описание плагина средствами языка UML. Разработка и реализация программных модулей.
дипломная работа [3,2 M], добавлен 12.08.2017История развития веб-технологий и существующие проблемы. Назначение и установка Symfony Framework. Создание приложения на основе технологий Symfony Framework. Установка дополнительных библиотек через composer, верстка шаблона, настройка сервисов.
дипломная работа [712,6 K], добавлен 05.07.2017Сведения о платформе Microsoft.NET Framework, способы и методы доступа к базам данных и системам управления базами данных, особенности проектирования и программирования баз данных средствами выше упомянутой платформы. Спроектировано приложение "Articles".
курсовая работа [5,9 M], добавлен 20.03.2011Обоснование потребности в web-сайте. Описание установки CMS Joomla. Постановка задачи при проектировании web-сайта. Обоснование выбора CMS (Content Management System). Разработка базы данных и интерфейса. Классификация и проектирование web-сайтов.
дипломная работа [1,9 M], добавлен 13.05.2009Разработка программного приложения по учету договоров с поставщиками и клиентами для строительного предприятия. Особенности использования технологии Net Framework 2.0 в алгоритмически-логическом аспекте на основе реляционной базы, управляемой языком SQL.
курсовая работа [3,0 M], добавлен 25.06.2011Разработка базы данных учета и хранения заявок пользователя. Создание программного средства на основе клиент/серверной технологии. Описание возможностей платформы Tandem Framework. Апробация программы автоматизации процессов подачи и обработки заявок.
дипломная работа [3,6 M], добавлен 08.03.2013Проект программного продукта, представляющего собой веб-приложение в виде системы управления веб-контентом и предназначенного для быстрого создания простых сайтов. Функциональные требования в рамках языка UML. Разработка визуальных интерфейсов системы.
дипломная работа [5,0 M], добавлен 11.07.2012Психолого-педагогические основы формирования системно-деятельностного подхода обучения. Обзор существующих конструкторов сайтов, обоснование выбора сервиса Wix. Ознакомление обучающихся с правилами безопасности в сети Интернет. Технологии создания сайтов.
дипломная работа [428,9 K], добавлен 07.09.2017Характеристика различных интернет-платформ, а также способов заработка на них. Преимущества и недостаки системы администрирования данных сайта WordPress, Joomla и 1-С Битрикс. Коммерческое программное обеспечение для управления контентом DataLife Engine.
курсовая работа [491,7 K], добавлен 26.12.2014Современные тенденции разработки и принципы классификации web-сайтов. Сайт как средство развития бизнеса. Технологии, применяемые при разработке web-сайтов, системы управления контентом. Разработка web-сайта для ЗАО "Кондитерская фабрика "Саратовская".
дипломная работа [4,1 M], добавлен 01.10.2012Методика и этапы проектирования ядра системы управления сайтом с помощью среды Zend Studio 8. Разработка обработчиков событий, для управления этой системой. Создание каскадных таблиц стилей для оформления панели администрирования с помощью Notepad++.
дипломная работа [4,6 M], добавлен 30.06.2011Преимущества и недостатки статических и динамических сайтов. Эволюция и классификация web-приложений. Требования, предъявляемые к системам управления контентом (CMS). Создание структуры сайта, информационное наполнение страниц. Разработка базы данных CMS.
дипломная работа [856,2 K], добавлен 27.06.2012Общие сведения о платформе Microsoft NET Framework. Разработка приложения "Поставка и реализация программного обеспечения", содержащего базу данных о каталогах адресов в Internet. Описание логической структуры. Требования к техническому обеспечению.
курсовая работа [2,4 M], добавлен 28.06.2011Анализ популярности мобильных операционных систем в мире и России. Разработка структурно-функциональной модели. Реализация серверной и клиентской частей программы. Алгоритм поиска события в мобильном приложении. Тестирование программного обеспечения.
дипломная работа [748,3 K], добавлен 10.07.2017Основные технологии разработки ресурсов Интернет. Процесс разработки веб-сайта. Понятие Web-сайта и классификация Web-сайтов. Основные этапы разработки Web-сайта. Использование HTML, CSS, JavaScript, FLASH, PHP и реляционной базы данных MySQL.
презентация [1,3 M], добавлен 28.11.2015Принципы построения Интернет-магазинов. Система Интернет-платежей. Структура электронного магазина, разработка его архитектуры, операционной, серверной, администраторской и клиентской частей. Алгоритма работы магазина. Экономическое обоснование проекта.
дипломная работа [2,4 M], добавлен 12.04.2012Критерии оценки сайтов при проведении Интернет-конкурса. Примеры популярных ресурсов с возможностью оценивания. Программная реализация плагина с использованием языков программирования HTML, CSS, PHP, JavaScript. Оценка качества разработанного продукта.
дипломная работа [2,6 M], добавлен 27.10.2017