Интернет-приложение файлового обмена с разграничением прав доступа

Технологии, используемые на стороне сервера: язык python, фреймворк Django, ORM, MVC, JSON, MySQL, веб-сервер Nginx, операционная система Linux. Разработка online хранилища данных. Программная реализация предметной области. Шаблоны вывода данных.

Рубрика Программирование, компьютеры и кибернетика
Вид дипломная работа
Язык русский
Дата добавления 25.04.2015
Размер файла 123,3 K

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.

CSS (англ. Cascading Style Sheets -- каскадные таблицы стилей) -- формальный язык описания внешнего вида документа, написанного с использованием языка разметки.

Преимущественно используется как средство описания, оформления внешнего вида веб-страниц, написанных с помощьюя зыков разметки HTML и XHTML, но может также применяться к любым XML-документам, например, к SVG или XUL.

CSS используется создателями веб-страниц для задания цветов, шрифтов, расположения отдельных блоков и других аспектов представления внешнего вида этих веб-страниц. Основной целью разработки CSS являлось разделение описания логической структуры веб-страницы (которое производится с помощью HTML или других языков разметки) от описания внешнего вида этой веб-страницы (которое теперь производится с помощью формального языка CSS). Такое разделение может увеличить доступность документа, предоставить большую гибкость и возможность управления его представлением, а также уменьшить сложность и повторяемость в структурном содержимом. Кроме того, CSS позволяет представлять один и тот же документ в различных стилях или методах вывода, таких как экранное представление, печатное представление, чтение голосом (специальным голосовым браузером или программой чтения с экрана), или при выводе устройствами, использующими шрифт Брайля.

Правила CSS пишутся на формальном языке CSS и располагаются в таблицах стилей, то есть таблицы стилей содержат в себе правила CSS. Эти таблицы стилей могут располагаться как в самом веб-документе, внешний вид которого они описывают, так и в отдельных файлах, имеющих формат CSS. По сути, формат CSS -- это обычный текстовый файл. В файле .css не содержится ничего, кроме перечня правил CSS и комментариев к ним.

То есть, эти таблицы стилей могут быть подключены, внедрены в описываемый ими веб-документ четырьмя различными способами:

когда таблица стилей находится в отдельном файле, она может быть подключена к веб-документу посредством тега <link>, располагающегося в этом документе между тегами <head> и </head>. (Тег <link> будет иметь атрибут href, имеющий значением адрес этой таблицы стилей). Все правила этой таблицы действуют на протяжении всего документа;

когда таблица стилей находится в отдельном файле, она может быть подключена к веб-документу посредством директивы @import, располагающейся в этом документе между тегами <style> и </style> (которые, в свою очередь, располагаются в этом документе между тегами <head> и </head>) сразу после тега <style>, которая также указывает (в своих скобках, после слова url) на адрес этой таблицы стилей. Все правила этой таблицы действуют на протяжении всего документа; (см.приложение 4.2)

когда таблица стилей описана в самом документе, она может располагаться в нём между тегами <style> и </style> (которые, в свою очередь, располагаются в этом документе между тегами <head> и </head>). Все правила этой таблицы действуют на протяжении всего документа; (см.приложение 4.3)

когда таблица стилей описана в самом документе, она может располагаться в нём в теле какого-то отдельного тега (посредством его атрибута style) этого документа. Все правила этой таблицы действуют только на содержимое этого тега. (см.приложение 4.4)

Как известно, HTML-документы строятся на основании иерархии элементов, которая может быть наглядно представлена в древовидной форме. Элементы HTML друг для друга могут быть родительскими, дочерними, элементами-предками, элементами-потомками, сестринскими[6].

Элемент является родителем другого элемента, если в иерархической структуре документа он находится сразу, непосредственно над этим элементом. Элемент является предкомдругого элемента, если в иерархической структуре документа он находится где-то выше этого элемента. Пускай, например, в документе присутствуют два абзаца p, включающие в себя шрифт с полужирным начертанием b. Тогда элементы b будут дочерними элементами своихродительских элементов p, и потомками своих предков body. В свою очередь, для элементов p элемент body будет являться только родителем. И кроме того, эти два элемента pбудут являться сестринскими элементами, как имеющими одного и того же родителя -- body.

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

1.2.3 JavaScript

JavaScript -- прототипно-ориентированный сценарный язык программирования. Является диалектом языка ECMAScript.

JavaScript обычно используется как встраиваемый язык для программного доступа к объектам приложений. Наиболее широкое применение находит в браузерах как язык сценариев для придания интерактивности веб-страницам.

Основные архитектурные черты: динамическая типизация, слабая типизация, автоматическое управление памятью, прототипное программирование, функции как объекты первого класса.

На JavaScript оказали влияние многие языки, при разработке была цель сделать язык похожим на Java, но при этом лёгким для использования непрограммистами. Языком JavaScript не владеет какая-либо компания или организация, что отличает его от ряда языков программирования, используемых в веб-разработке.

Название "JavaScript" является зарегистрированным товарным знаком компании Oracle Corporation.

В 1992 году компания Nombas (впоследствии приобретённая Openwave (англ.)) начала разработку встраиваемого скриптового языка Cmm (Си-минус-минус), который, по замыслу разработчиков, должен был стать достаточно мощным, чтобы заменить макросы, сохраняя при этом схожесть с Си, чтобы разработчикам не составляло труда изучить его. Главным отличием от Си была работа с памятью. В новом языке всё управление памятью осуществлялось автоматически: не было необходимости создавать буферы, объявлять переменные, осуществлять преобразование типов. В остальном языки сильно походили друг на друга: в частности, Cmm поддерживал стандартные функции и операторы Си. Cmm был переименован в ScriptEase, поскольку исходное название звучало слишком негативно, а упоминание в нём Си "отпугивало" людей[8].

На основе этого языка был создан проприетарный продукт CEnvi. В конце ноября 1995 года Nombas разработала версию CEnvi, внедряемую в веб-страницы. Страницы, которые можно было изменять с помощью скриптового языка, получили название Espresso Pages -- они демонстрировали использование скриптового языка для создания игры, проверки пользовательского ввода в формы и создания анимации. Espresso Pages позиционировались как демоверсия, призванная помочь представить, что случится, если в браузер будет внедрён язык Cmm. Работали они только в 16-битовом Netscape Navigator под управлением Windows.

Перед Бренданом Айком, нанятым в компанию Netscape 4 апреля 1995 года, была поставлена задача внедрить язык программирования Scheme или что-то похожее в браузер Netscape. Поскольку требования были размыты, Айка перевели в группу, ответственную за серверные продукты, где он проработал месяц, занимаясь улучшением протокола HTTP. В мае разработчик был переброшен обратно, в команду, занимающуюся клиентской частью (браузером), где он немедленно начал разрабатывать концепцию нового языка программирования. Менеджмент разработки браузера, включая Тома Пакина (Tom Paquin), Михаэля Тоя (англ.), Рика Шелла (Rick Schell), был убеждён, что Netscape должен поддерживать язык программирования, встраиваемый в HTML-код страницы.

Помимо Брендона Айка в разработке участвовали сооснователь Netscape Communications Марк Андрисин (англ.) и сооснователь Sun Microsystems Билл Джой: чтобы успеть закончить работы над языком к релизу браузера, компании заключили соглашение о сотрудничестве в разработке. Они ставили перед собой цель обеспечить "язык для склеивания" составляющих частей веб-ресурса: изображений, плагинов, Java-апплетов, который был бы удобен для веб-дизайнеров и программистов, не обладающих высокой квалификацией.

Первоначально язык назывался LiveScript и предназначался как для программирования на стороне клиента, так и для программирования на стороне сервера (там он должен был называться LiveWire). На синтаксис оказали влияние языки Си и Java, и, поскольку Java в то время было модным словом, 4 декабря 1995 года LiveScript переименовали в JavaScript, получив соответствующую лицензию у Sun. Анонс JavaScript со стороны представителей Netscape и Sun состоялся накануне выпуска второйбета-версии Netscape Navigator. В нём декларируется, что 28 лидирующих ИТ-компаний выразили намерение использовать в своих будущих продуктах JavaScript как объектный скриптовый язык с открытым стандартом[8].

В 1996 году компания Microsoft выпустила аналог языка JavaScript, названный JScript. Анонсирован этот язык был 18 июля 1996 года. Первым браузером, поддерживающим эту реализацию, был Internet Explorer 3.0.

По инициативе компании Netscape была проведена стандартизация языка ассоциацией ECMA. Стандартизированная версия имеет название ECMAScript, описывается стандартом ECMA-262. Первой версии спецификации соответствовал JavaScript версии 1.1, а также языки JScript и ScriptEasy. [7] [8]

1.2.4 jQuery

jQuery -- библиотека JavaScript, фокусирующаяся на взаимодействии JavaScript и HTML. Библиотека jQuery помогает легко получать доступ к любому элементу DOM, обращаться к атрибутам и содержимому элементов DOM, манипулировать ими. Также библиотека jQuery предоставляет удобный API по работе с AJAX.

HTML была одной из первых вещей, которую Джон Резиг освоил, когда он только начал заниматься программированием. Резиг программировал на QBasic, когда один его знакомый показал ему, как создать веб-страницу (используя Angelfire), а также основы HTML. Отец подарил ему на Рождество две книги по HTML. Именно тогда, когда он только начал программировать на Visual Basic, HTML и веб-дизайн очень заинтересовали его.

Но страсть к JavaScript пришла значительно позже, примерно в 2004 году. Тогда Резиг получал степень в области компьютерных наук и работал на полставки в местной фирме Brand Logic. Он занимался дизайном сайта, в котором создавался пользовательский скроллинг. Джон был разочарован и расстроен, особенно потому, что использовал код других разработчиков, после чего решил серьёзно изучить JavaScript. Изучив, пришел к выводам, что JavaScript -- это простой, но изящный язык, который является невероятно мощным для решения многих задач. В течение ближайшей пары лет Джон создал множество различных JavaScript-приложений, прежде чем закончить создание jQuery. Основной целью создания jQuery Резиг видел возможность закодировать многоразовые куски кода, которые позволят упростить JavaScript и использовать их так, чтобы не беспокоиться о кросс-браузерных вопросах. Библиотека была представлена общественности на компьютерной конференции "BarCamp" в Нью-Йорке в 2006 году.

Точно так же, как CSS отделяет визуализацию от структуры HTML, JQuery отделяет поведение от структуры HTML. Например, вместо прямого указания на обработчик события нажатия кнопки управление передаётся JQuery, которая идентифицирует кнопки и затем преобразовывает его в обработчик события клика. Такое разделение поведения и структуры также называется принципом ненавязчивого JavaScript.

Библиотека jQuery содержит функциональность, полезную для максимально широкого круга задач. Тем не менее, разработчиками библиотеки не ставилась задача совмещения в jQuery функций, которые подошли бы всюду, поскольку это привело бы к большому коду, бомльшая часть которого не востребована. Поэтому была реализована архитектура компактного универсального ядра библиотеки и плагинов. Это позволяет собрать для ресурса именно ту JavaScript-функциональность, которая на нём была бы востребована.

Вся работа с jQuery ведётся с помощью функции $. Если на сайте применяются другие JavaScript библиотеки, где $ может использоваться для своих нужд, то можно использовать её синоним -- jQuery.

Работу с jQuery можно разделить на 2 типа:

· Получение jQuery-объекта с помощью функции $(). Например, передав в неё CSS-селектор, можно получить jQuery-объект всех элементов HTML, попадающих под критерий и далее работать с ними с помощью различных методов jQuery-объекта. В случае, если метод не должен возвращать какого-либо значения, он возвращает ссылку на jQuery объект, что позволяет вести цепочку вызовов методов согласно концепции текучего интерфейса.

· Вызов глобальных методов у объекта $, например, удобных итераторов по массиву.

Типичный пример манипуляции сразу несколькими узлами DOM заключается в вызове $ функции со строкой селектора CSS, что возвращает объект jQuery, содержащий некоторое количество элементов HTML-страницы. Эти элементы затем обрабатываются методами jQuery.

Основные особенности jQuery:

· Легко осуществляет визуальные эффекты;

· Работает с событиями;

· Обращается и манипулирует любой элемент DOM - объектной модели документа;

· Кроссбраузерность;

· Предоставляет отличный API - интерфейс программирования приложений, для работы с Ajax - технологией, позволяющей общаться с сервером без перезагрузки страницы;

· Обладает большим количеством JavaScript плагинов, которые предназначены для создания элементов интерфейсов пользователей;

· Имеет подробную документацию с массой оригинальных примеров и подробными описаниями. [7] [8]

1.2.5 AJAX

AJAX-- "асинхронный JavaScript и XML") -- подход к построению интерактивных пользовательских интерфейсов веб-приложений, заключающийся в "фоновом" обмене данными браузера с веб-сервером. В результате, при обновлении данных веб-страница не перезагружается полностью, и веб-приложения становятся быстрее и удобнее. [7]

AJAX -- не самостоятельная технология, а концепция использования нескольких смежных технологий. AJAX базируется на двух основных принципах:

· использование технологии динамического обращения к серверу "на лету", без перезагрузки всей страницы полностью, например:

· с использованием XMLHttpRequest (основной объект);

· через динамическое создание дочерних фреймов;

· через динамическое создание тега <script>.

· через динамическое создание тега <img>, как это реализовано в google analytics.

· использование DHTML для динамического изменения содержания страницы;

Действия с интерфейсом преобразуются в операции с элементами DOM (англ. Document Object Model), с помощью которых обрабатываются данные, доступные пользователю, в результате чего представление их изменяется. Здесь же производится обработка перемещений и щелчков мышью, а также нажатий клавиш. Каскадные таблицы стилей, или CSS (англ. Cascading Style Sheets), обеспечивают согласованный внешний вид элементов приложения и упрощают обращение к DOM-объектам. Объект XMLHttpRequest (или подобные механизмы) используется для асинхронного взаимодействия с сервером, обработки запросов пользователя и загрузки в процессе работы необходимых данных[8].

Три из этих четырех технологий -- CSS, DOM и JavaScript -- составляют DHTML (англ. Dynamic HTML). По мнению некоторых специалистов средства DHTML, появившиеся в1997 году, подавали большие надежды, но так и не оправдали их.

В качестве формата передачи данных могут использоваться фрагменты простого текста, HTML-кода, JSON или XML.

Впервые термин AJAX был публично использован 18 февраля 2005 года в статье Джесси Джеймса Гарретта (Jesse James Garrett) "Новый подход к веб-приложениям". Гарретт придумал термин, когда ему пришлось как-то назвать новый набор технологий, предлагаемый им клиенту.

Однако в той или иной форме многие технологии были доступны и использовались гораздо раньше, например в подходе "Remote Scripting", предложенном компанией Microsoft в 1998 году, или с использованием HTML элемента IFRAME, появившегося в Internet Explorer 3 в 1996 году.

AJAX стал особенно популярен после использования его компанией Google в сервисах Gmail, Google Maps и Google Suggest.

Преимущества:

Экономия трафика

Использование AJAX позволяет значительно сократить трафик при работе с веб-приложением благодаря тому, что часто вместо загрузки всей страницы достаточно загрузить только изменившуюся часть, как правило, довольно небольшую.

Уменьшение нагрузки на сервер

AJAX позволяет несколько снизить нагрузку на сервер. К примеру, на странице работы с почтой, когда вы отмечаете прочитанные письма, серверу достаточно внести изменения в базу данных и отправить клиентскому скрипту сообщение об успешном выполнении операции без необходимости повторно создавать страницу и передавать её клиенту.

Ускорение реакции интерфейса

Поскольку нужно загрузить только изменившуюся часть, пользователь видит результат своих действий быстрее.

Обращения сайта к серверу не ограничиваются щелчками по ссылкам и отправкой форм

Например, при вводе запроса в Google выводится подсказка. На многих сайтах при регистрации пользователь вводит имя, и сразу же выводится, доступно это имя или нет; это тоже AJAX. AJAX удобен для программирования чатов, административных панелей и других инструментов, которые выводят меняющиеся со временем данные.

Недостатки:

Отсутствие интеграции со стандартными инструментами браузера

Динамически создаваемые страницы не регистрируются браузером в истории посещения страниц, поэтому не работает кнопка "Назад", предоставляющая пользователям возможность вернуться к просмотренным ранее страницам, но существуют скрипты, которые могут решить эту проблему. [7] [8] [10]

Другой недостаток изменения содержимого страницы при постоянном URL заключается в невозможности сохранения закладки на желаемый материал. Проблему можно успешно решить с помощью History.pushState.

Динамически загружаемое содержимое недоступно поисковикам (если не проверять запрос, обычный он или XMLHttpRequest)

Поисковые машины не могут выполнять JavaScript, поэтому разработчики должны позаботиться об альтернативных способах доступа к содержимому сайта.

Старые методы учёта статистики сайтов становятся неактуальными

Многие сервисы статистики ведут учёт просмотров новых страниц сайта. Для сайтов, страницы которых широко используют AJAX, такая статистика теряет актуальность.

Усложнение проекта

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

Требуется включенный JavaScript в браузере

JavaScript может быть выключен из соображений безопасности. И, конечно же, AJAX-страницы труднодоступны неполнофункциональным браузерам, роботам и веб-архивам.

Низкая скорость при грубом программировании

Казалось бы, AJAX предназначен именно для повышения скорости. Но, когда AJAX-запросов на одной странице много и, например, по каждому щелчку подгружается список, AJAX-страница становится даже медленнее традиционной.

Риск фабрикации запросов другими сайтами

Таковая возможна, когда результат работы AJAX-запроса является Javascript-кодом(в частности, JSON). XMLHttpRequest действует только в пределах одного домена, а вот тэг<script> -- нет. Если написать

<script type="text/javascript" src="http://example.org/inbox.php"></script>

то в HTML будет вставлена папка входящих сообщений того пользователя, который на этом компьютере авторизован на example.org. Для защиты используют POST-запрос. НоGET считается идемпотентным и потому кэшируется, POST -- нет, поэтому Google вставляет в начало ответа бесконечный цикл: AJAX может делать с ответом что угодно, в том числе убрать цикл, а тэг <script> подключит скрипт как есть и зациклится. [7] [10]

Глава 2. Разработка online хранилища данных

2.1 Постановка задачи

Целью разработки является создание системы с помощью HTML, CSS, Python, MySQL, JavaScript, которая реализует хранение файлов.

Система должна обладать следующим функционалом:

Регистрация/авторизация пользователей

Хранение файловой системы в БД

Создание, удаление, переименование, перемещение папок пользователя

Переименование, перемещение файлов пользователя

Поиск файлов среди загруженных пользователем

Загрузка файлов авторизованного пользователя на сервер

Загрузка файлов неавторизованного пользователя на сервер

Скачивание файлов пользователей, по генерируемым системой ссылкам

Редактирование пользователем регистрационной информации

Комнаты для организации совместного пользования файлами

Добавление, удаление файлов в комнатах пользователей

Скачивание файлов из комнат пользователей по генерируемым системой ссылкам

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

2.2 Реализация системы

2.2.1 Предметная область

Предметная область задачи включает следующие объекты реального мира: файлы и папки. Пользователям необходимо предоставлять личный каталог на сервере, где они могут создавать подкаталоги и оперировать ими: переименовывать перемещать и удалять. Также нужно давать пользователям возможность загружать файлы на сервер в указанный каталог, скачивать файлы с сервера, получать ссылки на скачивание файлов для того, чтобы поделиться файлами с другими пользователями.

2.2.2 Программная реализация предметной области

Класс Folder (каталог, папка)

Модель описывает сущность "каталог", содержит поля:

parent - указатель на каталог выше уровнем

user - указатель на пользователя, которому принадлежит каталог

name - имя каталога

share - булевское поле, содержащее информацию о возможности или невозможности скачивания файла другими пользователями или гостями сайта.

Класс File (файл)

Класс описывает сущность "файл", содержит поля:

name - имя файла

file - имя присеваемое файлу системой при загрузки его на сервер

size - размер загружаемого файла на сервер

folder - указатель на виртуальную папку в которой хранится файл

user - указатель на пользователя, которому принадлежит файл

Класс Room (комнаты)

Класс описывает сущность "комнаты", содержит поля:

name - название комнаты

maker - указатель на пользователя создавшего комнату

share - булевское поле, содержащее информацию о возможности или невозможности скачивания файлов внутри комнаты "гостем", т.е. пользователем не состоящим в комнате

Класс RoomUse ()

Класс описывает отношения "комнат и пользователей", содержит поля:

room - указатель на комнату

user - указатель на пользователя

approve - булевское поле, содержащее информацию о том подтвердил ли пользователь свое намерение состоять в комнате

2.2.3 Функции представления

Перед тем как рассматривать конкретные функции представления, рассмотрим схему работы Веб-приложения (Рис.1)

Рис.1. Схема работы веб-приложения

После того как пользователь запросил страницу нашего ресурса, системе, необходимо знать какую функцию представления (обработчик) необходимо выполнить. Информация о сопоставлении url-адресов и функции представлении содержится в urls.py.

Набор функций представлений содержится в файле views.py. В процессе выполнения конкретного обработчика необходимо производить действия над свойствами и вызывать методы различных объектов.

Информация о методах и свойствах находится в файле models.py.

По завершении выполнения обработчик передает данные шаблонизатору для вывода на интерфейс пользователя.

Таким образом, выполнение Веб-приложения сводится к выполнению конкретных обработчиков по конкретным url-адресам.

2.2.4 Шаблоны вывода данных

Шаблоны вывода данных представляют собой файлы, содержащие html-шаблон вывода и исполняемый код шаблонизатора.

Код шаблонизатора выполняется при формировании http-ответа. Шаблонизатор вгружает полученные на вход данные в соответствующий html-шаблон, а на выходе возвращает html-код.

Рассмотрим конкретные шаблоны нашего приложения:

· Main-page.htt - шаблон главной страницы.(см. листинг 5)

· Files-page.htt - шаблон представлении файловой системы (см. листинг 6)

· Rooms-page.htt - шаблон представление комнат(см. листинг 7)

Заключение

В результате проведённой работы был разработан веб-ресурс, который позволяет пользователям загружать файлы на сервер и обмениваться ими.

Данная система является удобным средством для хранения и транспортировки данных.

Список литературы

Пэйн Дж., Начиная с Python: Использование Python 2.6 и Python 3.1 / Д. Пэйн: Wiley Publishing, 2009. - 624 с.

Головатый А., Django: Подробное руководство / Адриан Головатый, Джейкоб Каплан-Мосс : Символ-Плюс, 2010. - 560 с.

Фаулер М., Архитектура корпоративных программных приложений / Мартин Фаулер : Адисон-Венсли, 2012. - 560 с.

Фримен А., ASP.NET MVC 3 Framework с примерами на C# для профессионалов / Адам Фримен, Стивен Сандерсон : Вильямс, 2012. - 667 с.

Дюбуа П., MySQL / Поль Дюбуа; пер. с англ, Воронин В.:Вильямс, 2007. -1168 с.

Соколов, С. А. HTML и CSS в примерах, типовых решениях и задачах. Профессиональная работа./ С. А. Соколов. -- М.: Вильямс, 2007.

Википедия - сводная энциклопедия [Электронный ресурс] // ru.wikipedia.org

Блог веб-разработчика - блог [Электронный ресурс] // true-coder.ru

Школа XHTML - уроки [Электронный ресурс] // xhtml.co.il/ru/

Уроки по AJAX - уроки [Электронный ресурс] // ajaxs.ru

Приложение 1

Простой CGI код на Python.

#!/usr/bin/env python

import MySQLdb

print "Content-Type: text/html"

print

print "<html><head><title>Книги</title></head>"

print "<body>"

print "<h1>Книги</h1>"

print "<ul>"

connection = MySQLdb.connect(user='me', passwd='letmein', db='my_db')

cursor = connection.cursor()

cursor.execute("SELECT name FROM books ORDER BY pub_date DESC LIMIT 10")

for row in cursor.fetchall():

print "<li>%s</li>" % row[0]

print "</ul>"

print "</body></html>"

connection.close()

Как можно написать предыдущий CGI код, воспользовавшись возможностями Django.

models.py:

from django.db import models

class Book(models.Model):

name = models.CharField(max_length=50)

pub_date = models.DateField()

views.py:

from django.shortcuts import render_to_response

from models import Book

def latest_books(request):

book_list = Book.objects.order_by('-pub_date')[:10]

return render_to_response('latest_books.htt', {'book_list': book_list})

urls.py:

from django.conf.urls.defaults import *

import views

urlpatterns = patterns('',

(r'^latest/$', views.latest_books),

)

Latest_books.htt:

<html><head><title>Книги</title>

</head>

<body>

<h1>Книги</h1>

<ul>

{% for book in book_list %}

<li>{{ book.name }}</li>

{% endfor %}

</ul>

</body>

</html>

Приложение 2

var the_object;

var http_request = new XMLHttpRequest();

http_request.open( "GET", url, true );

http_request.send(null);

http_request.onreadystatechange = function () {

if ( http_request.readyState == 4 ) {

if ( http_request.status == 200 ) {

the_object = JSON.parse(http_request.responseText);

} else {

alert( "There was a problem with the URL." );

}

http_request = null;

}

};

Приложение 3

Пример веб--страницы HTML5

<!doctype html>

<html>

<head>

<meta charset=utf-8>

<title>(Это title) Пример страницы на HTML5</title>

</head>

<body>

<header>

<hgroup>

<h1>Заголовок "h1" из hgroup</h1>

<h2>Заголовок "h2" из hgroup</h2>

</hgroup>

</header>

<nav>

<a href=link1.html>Первая ссылка из блока "nav"</a>

<a href=link2.html>Вторая ссылка из блока "nav"</a>

</nav>

<section>

<article>

<h1>Заголовок статьи из блока "article"</h1>

<p>Текст абзаца статьи из блока "article"</p>

<details>

<summary>Блок "details", текст тега "summary"</summary>

<p>Абзац из блока "details"</p>

</details>

</article>

</section>

<footer>

<time>Содержимое тега "time" блока "footer"</time>

<p>Содержимое абзаца из блока "footer"</p>

</footer>

</body>

</html>

сервер операционный хранилище шаблон

Приложение 4

<head>

.....

<link rel="stylesheet" type="text/css" href="style.css">

</head>

<head>

.....

<style type="text/css" media="all">

@import url(style.css);

</style>

</head>

<head>

.....

<style type="text/css">

body {

color: red;

}

</style>

</head>

<p style="font-size: 21px; color: green;">Рассказ</p>

Селекторы правила CSS могут быть:

· универсальный селектор;

* {margin:0; padding:0;}

· селекторами элементов;

p {font-family: Garamond, serif;}

· селекторами классов;

.note {color: red; background: yellow; font-weight: bold;}

· селекторами идентификаторов;

#paragraph1 {margin: 0;}

· селекторами атрибутов;

a[href="http://www.somesite.com"]{font-weight:bold;}

· селекторами потомков (контекстными селекторами);

div#paragraph1 p.note {color: red;}

· селекторами дочерних элементов;

p.note > b {color: green;}

· селекторами сестринских элементов;

h1 + p {font-size: 24pt;}

· селекторами псевдоклассов;

a:active {color:yellow;}

· селекторами псевдоэлементов.

p::first-letter {font-size: 32px;}

Листинг 1

class Folder(models.Model): parent = models.ForeignKey('self', null = True, blank = True) user = models.ForeignKey(User) name = models.CharField(u'Имя', max_length = 32, help_text = u'Имя папки') share = models.BooleanField(default=False) def __unicode__(self): return self.name class Meta: db_table = 'folders'

Листинг 2

class File(models.Model):

name = models.CharField(u'Имя', max_length = 32, help_text = u'Имя файла') file = models.FileField(u'Файл для загрузки', upload_to = 'uploads') size = models.IntegerField(u'Размер файла') folder = models.ForeignKey(Folder, null = True) user = models.ForeignKey(User, null = True) def __unicode__(self): return self.name class Meta: db_table = 'files'

Листинг 3

class Room(models.Model):

name = models.CharField(u'Имя', max_length = 32, help_text = u'Имя комнаты') maker = models.ForeignKey(User) share = models.BooleanField(default=False) def __unicode__(self): return self.name class Meta: db_table = 'room'

Листинг 4

class Room_Use(models.Model):

room = models.ForeignKey(Room) user = models.ForeignKey(User) approve = models.BooleanField(default=False) def __unicode__(self): return self.room class Meta: db_table = 'room_users'

Листинг 5

{% extends 'page.htt' %} {% block content %} <center style="margin-top:20%;"> <a href="/door/" class="link link1">Вход</a> <a href="/register/" class="link link2">Регистрация</a> <div class="clr"></div> <a href="/upload/" class="link link3">Загрузить файл...</a> </center> {% endblock %}

Листинг 6

{% extends 'page.htt' %}

{% block login_info %}

<div class="login-info">

<img src="/media/user/{{ username }}.png" width="50" height="50" />

<p>

<span>{{ username }}</span><br>

<a style="cursor:pointer;" onClick="showPopup('ProfilePopup');">Профиль</a><br>

<a href="/logout/">Выйти</a>

</p>

</div>

{% endblock %}

{% block content %}

<table width="100%" height="100%" id="createFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('createFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('createFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Создать"

<INPUT type="text" name="new_folder" id="folder_name" /><br><br><button onClick="createFolder();">Создать</button>

</div></td>

<td onClick="hidePopup('createFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('createFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="renameFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('renameFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('renameFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Переименовать"

<input type="text" name="rename_folder" id="renameInput"/><br><br><button onClick="renameFolder();">Переименовать</button>

</div></td>

<td onClick="hidePopup('renameFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('renameFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="moveFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('moveFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('moveFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="380"><div class="form">Это окно для "Переместить"</div></td>

<td onClick="hidePopup('moveFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('moveFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="uploadFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('uploadFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Загрузить файл..."</div></td>

<td onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="ProfilePopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('ProfilePopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('ProfilePopup');"></td>

<td valign="middle" align="center" width="300" height="427"><div class="form">Это окно для "Профиль"</div></td>

<td onClick="hidePopup('ProfilePopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('ProfilePopup');"></td>

</tr>

</table>

<table width="960px" height="100%" cellpadding="0" cellspacing="0" border="0">

<tr>

<td class="left-menu">

<table id="tree-table" width="100%" height="100%" cellpadding="0" cellspacing="10">

<tr>

<td class="search buttons" colspan="2">

<input type="text" name="src" placeholder="Поиск файлов..." />

</td>

</tr>

<tr>

<td class="buttons"><a class="button current">Файлы</a></td>

<td class="buttons"><a href="/rooms" class="button">Комнаты</a></td>

</tr>

<tr>

<td class="tree-area" id="tree-area" colspan="2">

{% autoescape off %}

{{ tree }}

{% endautoescape %}

</td>

</tr>

<tr>

<td class="buttons">Общий доступ</td>

<td class="buttons"></td>

</tr>

<tr>

<td class="buttons"><a class="button" onClick="showPopup('createFolderPopup');">Создать</a></td>

<td class="buttons"><a class="button" onClick="deleteFolder();">Удалить</a></td>

</tr>

<tr>

<td class="buttons"><a class="button" onClick="showPopup('renameFolderPopup');">Переименовать</a></td>

<td class="buttons"><a class="button" onClick="showPopup('moveFolderPopup');">Переместить</a></td>

</tr>

</table>

</td>

<td>

<table id="files" width="100%" height="100%" cellpadding="0" cellspacing="10" border="0">

<tr>

<td align="center" class="upload buttons">

<a class="button" onClick="showPopup('uploadFolderPopup');">Загрузить файл...</a>

</td>

</tr>

<tr>

<td class="files">

<article id="article">

</article>

</td>

</tr>

</table>

</td>

</tr>

</table>

{% endblock %}

Листинг 7

{% extends 'page.htt' %}

{% block login_info %}

<div class="login-info">

<img src="/media/user/{{ username }}.png" width="50" height="50" />

<p>

<span>{{ username }}</span><br>

<a style="cursor:pointer;" onClick="showPopup('ProfilePopup');">Профиль</a><br>

<a href="/logout/">Выйти</a>

</p>

</div>

{% endblock %}

{% block content %}

<table width="100%" height="100%" id="createRoomPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('createRoomPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('createRoomPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Создать"

<INPUT type="text" name="new_folder" id="folder_name" />&nbsp;<button onClick="createRoom();">Создать</button>

</div></td>

<td onClick="hidePopup('createRoomPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('createRoomPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="renameFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('renameFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('renameFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Переименовать"</div></td>

<td onClick="hidePopup('renameFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('renameFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="moveFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('moveFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('moveFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="380"><div class="form">Это окно для "Переместить"</div></td>

<td onClick="hidePopup('moveFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('moveFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="uploadFolderPopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('uploadFolderPopup');"></td>

<td valign="middle" align="center" width="300" height="167"><div class="form">Это окно для "Загрузить файл..."</div></td>

<td onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('uploadFolderPopup');"></td>

</tr>

</table>

<table width="100%" height="100%" id="ProfilePopup" cellpadding="0" cellspacing="0" border="1">

<tr>

<td colspan="3" onClick="hidePopup('ProfilePopup');"></td>

</tr>

<tr>

<td onClick="hidePopup('ProfilePopup');"></td>

<td valign="middle" align="center" width="300" height="427"><div class="form">Это окно для "Профиль"</div></td>

<td onClick="hidePopup('ProfilePopup');"></td>

</tr>

<tr>

<td colspan="3" onClick="hidePopup('ProfilePopup');"></td>

</tr>

</table>

<table width="960px" height="100%" cellpadding="0" cellspacing="0" border="0">

<tr>

<td class="left-menu">

<table id="tree-table" width="100%" height="100%" cellpadding="0" cellspacing="10">

<tr>

<td class="search buttons" colspan="2">

<input type="text" name="src" placeholder="Поиск файлов..." />

</td>

</tr>

<tr>

<td class="buttons"><a href="/files" class="button">Файлы</a></td>

<td class="buttons"><a class="button current">Комнаты</a></td>

</tr>

<tr>

<td class="tree-area" id="tree-area" colspan="2">

{% autoescape off %}

{{ tree }}

{% endautoescape %}

</td>

</tr>

<tr>

<td class="buttons">Общий доступ</td>

<td class="buttons"></td>

</tr>

<tr>

<td class="buttons"><a class="button" onClick="showPopup('createRoomPopup');">Создать</a></td>

<td class="buttons"><a class="button" onClick="deleteRoom();">Удалить</a></td>

</tr>

<tr>

<td class="buttons"><a class="button" onClick="showPopup('renameRoomPopup');">Переименовать</a></td>

<td class="buttons"><a class="button" onClick="showPopup('partiRoomPopup');">Участники</a></td>

</tr>

</table>

</td>

<td>

<table id="files" width="100%" height="100%" cellpadding="0" cellspacing="10" border="0">

<tr>

<td align="center" class="upload buttons">

<a class="button" onClick="showPopup('uploadRoomPopup');">Загрузить файл...</a>

</td>

</tr>

<tr>

<td class="files">

<article id="article">

</article>

</td>

</tr>

</table>

</td>

</tr>

</table>

{% endblock %}

Размещено на Allbest.ru


Подобные документы

  • Средства, используемые при разработке интернет-приложения. Язык обработки сценариев на стороне web-сервера. Система управления базами данных MySQL. Проектирование front-offiсe. Проектирование ER модели данных с использованием модели "сущность-связь".

    курсовая работа [3,5 M], добавлен 15.01.2014

  • Django — свободный фреймворк для веб-приложений на языке Python, использующий шаблон проектирования MVC. Архитектура и основные компоненты приложения. Главные компоненты среды разработки Django. Некоторые возможности и взаимосвязь компонентов фреймворка.

    реферат [23,7 K], добавлен 18.01.2015

  • Общие сведения об операционной системе Linux. Анализ информации о серверах. Основные прикладные клиент-серверные технологии Windows. Сведения о SQL-сервере. Общая информация о MySQL–сервере. Установка и специфика конфигурирования MYSQL-сервера на LINUX.

    курсовая работа [1,3 M], добавлен 16.12.2015

  • Системный анализ предметной области. Выбор инструментальных средств для создания программного обеспечения. Программирование на стороне SQL-сервера. Создание клиентского Win-приложения, пользовательский интерфейс. Физическое проектирование базы данных.

    курсовая работа [3,7 M], добавлен 20.11.2013

  • Виды серверов баз данных. MySQL как наиболее приспособленная для применения в среде СУБД. Хранимые и присоединенные процедуры. Операционная среда серверов. Согласованность чтения и тупиковые ситуации. Установка и настройка MySQL Server 5.6 на Windows 7.

    курсовая работа [3,0 M], добавлен 28.12.2015

  • Отличительные особенности языков программирования PHP и CSS. Возможности компактного многопоточного сервера баз данных MySQL. Системный анализ предметной области, проектирование ее инфологической модели. Создание базы данных и web-страниц сайта магазина.

    курсовая работа [1,0 M], добавлен 15.01.2013

  • Компоненты приложения Vue.js, использование шаблона MVVM. Характеристика Webpack и фреймворка NuxtJs. Python как язык программирования, модель MVC, компоненты и инструментарий фреймворка Django. Технология программирования Object Relational Mapping.

    контрольная работа [296,4 K], добавлен 22.03.2017

  • Основные технологии веб-программирования. Методы отправки данных на сервер с помощью HTML-формы. PHP - Препроцессор Гипертекста. Сохранение данных в базе данных MySQL. Клиент-Сервер и технология CGI. Примеры использования PHP совместно с MySQL.

    лекция [2,9 M], добавлен 27.04.2009

  • Общее понятие, основные компоненты и функции операционной системы. Порядок установи операционной системы UbuntuLinux. Особенности инсталляции веб-сервера Nginx для передачи данных по протоколу HTTP. Установка системы управления базами данных MongoDB.

    курсовая работа [2,3 M], добавлен 11.06.2014

  • Анализ предметной области "Ремонт часов", с использованием СУБД MySQL, языка HTML, технологии PHP и ADO и выбора скриптовых языков VBScript или JavaScript. Нормализация базы данных. Пошаговое описание нормализации базы данных (методом ER-диаграмм).

    курсовая работа [782,4 K], добавлен 18.06.2010

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.