Репозиторий для реализации дистанционного обучения по дисциплине "Web-программирование".
Учебный журнал по дисциплине. Тут доступна информация о сроках сдачи работ, о текущей успеваемости студентов и описаны все материалы необходимые для реализации курса.
Составляющие финальной оценки:
- 70 баллов - лабы (их делать обязательно). В курсе всего 4 работы.
- 10 баллов - тесты.
- 10 баллов - дисскусии на практиках (1+ доклад за семестр). Доклад на 5-7 минут. Нужны примеры кода или модели процессов, которые ведется речь в докладе.
- 10 - экзамен.
При выполнении всех лаб по дисциплине в срок + две недели - экзамен-автомат.
Все лабы необходимо сдать до 20 декабря, иначе есть риск, что преподаватель не успеет их проверить.
Если лабораторная работа выполнена не в срок, требуется получить допуск к ее защите. Для допуска необходимо выполнть задания на https://leetcode.com/. 1 неделя просрочки - 1 задание.
Преподавателю можно писать в телеграмме, при возможности он ответит (преподаватель не обязан отвечать в месенджерах во внеурочное врем). Лучше прийти на пару и спросить лично.
Дополнительные материалы делятся на 3 категории:
- Для тех, кто считает, что имеет недостаточно базовых знаний об информатике, веб-разработке и сетях (обзначается (+)).
- Для тех, кто считает, что имеет базовые знания (обзначается (++)).
- Для тех, кто хочет поглубже изучить материал (обзначается (+++)).
Презентация с лекции тут.
Допонительные материалы:
- Иерархия компьютерных информационных систем для разработки сайта (+)
- Топ-5 наиболее популярных CMS: какую выбрать? (++)
- Веб-фреймворки: введение для новичков (классификация фреймворков) (++)
- Чем отличаются фронтенд- и бэкенд-разработка (+)
- Что такое MVC: базовые концепции и пример приложения (++)
Важное сообщение для тех, кому "препод опять втирает какую-то ненужную лабу непонятно про что". Эта лабораторная работа и заданя в ней помогут Вам понять, как происходит сетевое взаимодействие в вебе, и не только. Сокеты используеются всегда, при любом сетевой взаимодействии. Если Вы будете веб-разработчиком, Вам придется работать с средствами, которые их используют (100%) и настраивать их в ручную (очень вероятно).
Лекция с практики
Текст работы
В документации по работе можно найти теорию по работе, примеры на python, задание.
Общий срок сдачи: 30.09.2024 (включительно) (необходимо отправить pull-реквест с работой).
- Выполнение пунктов 1-4 и однопользовательского чата (без потоков) — 60% баллов.
- Выполнение пунктов 1-5 и многопользовательского чата (с потоками) — 100% баллов.
Полученную модель, код и отчет залить в папку репозитория students/группа/laboratory_works/фамилия_имя/laboratory_work_1. Инструкция о загрузке работы ниже. Не забывайте о файле gitignor.
Необходимо сделать отчет. Все отчеты делаются средствами markdown и mkdocs. Инструкция по созданию веб-страничек из markdown средствами mkdocs доступна тут в пункте 3.2.2 https://docs.google.com/document/d/1rIfREFvCB4pp8uF990Tz3PLXRJ5u_w-Y3vLxfXWKoxg/edit?usp=sharing . Краткое описание работы с markdown доступно в пункте 3.1
Как делать пул-реквест описано в разделе Сдача работ
Те студенты, которые хотят получить более обширное представление о работе с конструкторами сайтов, могут пройти этот курс.
Цель работы: дать краткое представление о работе Django WEB фреймворка.
Необходимо выполнить все задания с пометкой практическая работа из практической работы №1.
Полученную программу загрузить в папку этого репозитория sutdents/группа/practical_works/фамилия_имя/simple_django_web_project. Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Для удобства навигации по практическим работам необходимо открыть меню оглавления (см. скриншоты ниже)
Цель работы: дать подробное представление о реализации CRUD(Create, read, update and delete) интерфейсов средствами Django WEB фреймворка.
Необходимо выполнить все задлания с пометкой практическая работа из практической работы №2.
Полученную программу залить в папку этого репозитория sutdents/группа/practical_works/фамилия_имя/simple_django_web_project. Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Необходимо выполнить все задлания с пометкой практическая работа из практической работы №3.
Полученную программу залить в папку этого репозитория sutdents/группа/practical_works/фамилия_имя/simple_django_web_project. Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Реализовать веб сервис, в соответствии с вариантом из задания (студент с порядковым номером 6 в списке группы делает 6 вариант, седьмой - вариант номер 1).
Текст лабораторной работы тут.
Срок сдачи: **** (включительно)
Обращаем внимание, что доступна возможность предложить свой индивидуальный вариант и делать работу по нему.
Если Вы хотите индивидуальный враиант, советуем не использовать вариант из дисциплины "Адаптивный веб-дизайн" в этой работе, эффективнее Вы сможете его использовать в следующих работах.
Чтобы продлить срок, необходимо:
- Реализовать меню (меню с бутсрап - https://www.youtube.com/watch?v=HEPTgggsRgY)
- Реализвать пагинацию страниц (так себе вариант - https://evileg.com/ru/post/10/ , отличный вариант - https://evileg.com/ru/post/237/)
- Внедрить поиск по объектам, с которыми настроена пагинация (https://evileg.com/ru/post/21/)
Фундаментально - плейлист уроков по джанго для тех кто хочет фундаментально изучить, как работает джанго веб фремйворк и заниматься этим в будущем.
Базово - плейлист, который позволит быстро понять, как и что работает и сделать лабу.
Все файлы загрузить в папку students/группа/laboratory_works/фамилия_имя/laboratory_work_2. Инструкция о загрузке работы ниже. Не забывайте о файле gitignor.
Необходимо сделать отчет. Все отчеты делаются средствами markdown и mkdocs. Инструкция по созданию веб-страничек из markdown средствами mkdocs доступна тут в пункте 3.2.2 https://docs.google.com/document/d/1rIfREFvCB4pp8uF990Tz3PLXRJ5u_w-Y3vLxfXWKoxg/edit?usp=sharing . Краткое описание работы с markdown доступно в пункте 3.1
Как делать пул-реквест описано в разделе Сдача работ
Цель работы: овладеть практическими навыками реализации серверной части (backend) приложений средствами Django REST framework.
Записи лекций доступны в телеграмм канале.
- простой курс - плейлист уроков по джанго для тех, кто хочет быстро изучить, как работает работает Django rest framework в связке с vue.js. (Примечание. В уроке 4 изменился путь для получения токена авторизации (см. официальную докумекнтацию Djoser https://djoser.readthedocs.io/en/latest/getting_started.html))
- более подробный курс, чем в пункте 1
Цель работы: получить представление о работе с запросами в Django ORM.
Необходимо выполнить все задания с пометкой Практическое задание [из практической работы №3.1] (https://docs.google.com/document/d/1jB8EYOWk-bbjB6sLr1s7dOmLYRC9Z5jIV6xIpnigdvY/edit?usp=sharing).
Полученную программу залить в папку этого репозитория sutdents/группа/practical_works/фамилия_имя/simple_drf_project.
Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Сдача практический работы №3.1: Оформить, как часть документации все задания с пометкой "практическая работа" и сдать Сергею.
Цель работы: получить представление об использовании возмжностей работы контроллеров и серриализаторов в Django Rest Framework.
Необходимо выполнить все задания с пометкой "Практическое задание [из практической работы №3.2] (https://docs.google.com/document/d/1PkpwxCUYQ2_Pi8Fpcgno6te3oCQHZfkh03Zxt6DhHSw/edit?usp=sharing).
Полученную программу залить в папку этого репозитория sutdents/группа/practical_works/фамилия_имя/simple_drf_project.
Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Цель работы: овладеть навыками написания документации к API.
Необходимо выполнить все задания с пометкой "Практическое задание" из практической работы №3.3.
Результаты практики загружаются в репозиторий вместе с лабораторной работой.
Срок сдачи общий для всех групп 2.12.2024
Реализация серверной части приложения средствами django и djangorestframework в соответствии с заданием из текста работы.
Порядок выполнения работы:
- Выполнить Практические работы 3.1 и 3.2
- Выбрать вариант или предложить свой, есть 3 способа:
2.1. Предложить свой вариант.
2.3. Выбрать вариант из вариантов по курсу «Основы баз данных» (https://drive.google.com/file/d/174gPjJ7AOHfzteYcobPY0x7sFBTkN1Xx/view?usp=sharing).
2.3. Использовать вариант из курса Давида по фронтент-разработке. 2.4. Если хочется сделать что-то полнофункциональное для порфтолио и задеплоить, можно поговорить с Антоном Игореувичем и он предложит несколько важных для него тем (при этом варианте шаги по работе чаще нужно будет согласовывать с преподавателями). По любому из способов функционал нужно согласовать с преподавателем или ментором. В лабораторной работе №4 необходимо будет реализовать клиентскую часть(фронтенд) по этому же варианту. - Реализовать модель базы данных средствами DjangoORM (согласовать с преподавателем на консультации).
При необходимости, студент может согласовать модель базы данных с преподавателем и только потом приступить к описанию модели средствами Django ORM
Полезные материалы:
- Реализовать логику работу API средствами Django REST Framework (используя методы сериализации).
Полезные материалы:
- Пункты 4, 5, 6 в Практической работе 3.1
- DJANGO API VIEWS, GENERICS, FILTER (Видео)
- JSON. Сериализация данных. Пишем свой сериализатор. Разбираем Django REST Framework Serializers (Видео)
- Работа с Django ORM (Видео)
- Пункты 4, 5, 6 в Практической работе 3.1
- Подключить регистрацию / авторизацию по токенам / вывод информации о текущем пользователе средствами Djoser.
Полезные материалы:
- Выполнить практическую работу 3.2 по оформлению документации (в процессе разработки)
- Реализовать документацию, описывающую работу всех используемых endpoint-ов из пункта 3 и 4 средствами Read the Docs или MkDocs.
Полезные материалы:- Пункт 3 из практической работы №3.2
Работа выполняется индивидуально.
Код практический и лабораторной части должен быть загружен в репозиторий курса, в соответствии с инструкциями тут.
Работу необходимо защитить на консультации или прислать видео с описанием проделанной работы.
Работа выполняется индивидуально.
Полученную программу залить в папку этого репозитория sutdents/группа/laboratory_works/фамилия_имя/laboratiry_work_3. Сделать страницу документации по работе в вашем mkdocs по всем работам. Описать в документации модель данных, важный блоки кода, ендпоинты. Инструкция о загрузке работы ниже. Не забывайте о файле gitignore.
Работу необходимо защитить лично.
Цель работы: Ознакомится с базовыми конструкциями JavaScript. Текст "Практической работы №4.1 (сдавать не нужно, можно не делать, если базово знаете JS).
Цель работы: получить представление о работе Vue.js. Текст "Практической работы №4.2.
Цель работы: получить практические навыки настройки CORS (Cross-origin resource sharing). Текст "Практической работы №4.3.
Срок сдачи 25.12.2024
Реализация клиентской части приложения средствами vue.js.
Порядок выполнения работы:
- Выполнить практическую работу 4.1 Базовые конструкции языка JavaScript). (https://docs.google.com/document/d/1lurVq_ddbKQ-rORvxF3T9PlPPy-sOgHwFazCI0yEqYY/edit?usp=sharing)
- Выполнить практическую работу 4.2. Работа с Vue.JS. (https://docs.google.com/document/d/1kSXkW6Vcis8z-TunNALcapCVmMHps3jaDdIP4rZkV9E/edit?usp=sharing)
- Настроить для серверной части, реализованной в лабораторной работе №3 CORS (Cross-origin resource sharing) в соответствии с Практической работой 4.3
- Утвердить с одним из преподавателей список интерфейсов для взаимодействия с серверной частью в соответствии с вашей предметной областью (это очень важный пункт, тк бывает такое, что не все студенты понимают суть своих вариантов).
- Реализовать интерфейсы авторизации, регистрации и изменения учётных данных и настроить взаимодействие с серверной частью.
Полезные материалы:
- Настройка авторизации средствами Vue.js и Django REST framework (DjangoSchool) (ссылка)
- Настройка авторизации средствами Vue.js и Django REST framework (DjangoSchool) (ссылка)
- Реализовать клиентские интерфейсы и настроить взаимодействие с серверной частью (интерфейсы из пункта 4).
Полезные материалы:
- Пункты 4.2, 4.3, 4.5 в Практической работе 4.2
- В освоении VUE 3 может помочь данный урок урок
- Пункты 4.2, 4.3, 4.5 в Практической работе 4.2
- Подключить vuetify или аналогичную библиотеку.
Полезные материалы:
- Пункт 3.1 в Практической работе 4.2
- Пункт 3.1 в Практической работе 4.2
- Реализовать документацию, описывающую работу разработанных интерфейсов средствами MkDocs.
Работа выполняется индивидуально.
Полученную программу залить в папку этого репозитория sutdents/группа/laboratory_works/фамилия_имя/laboratiry_work_4. Инструкция о загрузке работы ниже. Не забывайте о файле gitignore. Реализовать документацию, описывающую работу разработанных интерфейсов средствами MkDocs.
Работу необходимо защитить лично или прислать видео с описанием проделанной работы.
Все отчеты делаются средствами markdown и mkdocs. Инструкция по созданию веб-страничек из markdown средствами mkdocs доступна тут в пункте 3.2.2 https://docs.google.com/document/d/1rIfREFvCB4pp8uF990Tz3PLXRJ5u_w-Y3vLxfXWKoxg/edit?usp=sharing . Краткое описание работы с markdown доступно в пункте 3.1
Все отчеты должны храниться на одном "сайте", сгенерированном из ваших markdown файлов в форке этого репозитория.
Работы необходимо показать преподавателю на практическом занятии (в работающем виде).
Весь студенческий код необходимо загрузить в папку Students Для загрузки работы необходимо:
- Зарегистрироваться на Git.
- Сделать форк репозитория с заданиями в свой аккаунт (на странице https://github.com/TonikX/ITMO_ICT_WebDevelopment_2024-2025 кнопка fork справа, сверху).
- Установить Git на компьютер.
- Открыть папку, где хранятся Ваши проекты. В контекстом меню нажать "Open Git Bash here". Склонировать форкнутый репозиторий на комьютер (git clone https://github.com/ваш аккаунт/ITMO_ICT_WebDevelopment_2024-2025).
- В файловой системе Вашего компрьютера в склонированном репозитории создать в папке students/группа Вашу личную папку в формате Фамилия_Имя латиницей (Пример students/k3340/Petrov_Vasya).
- В личной папке сделать подпапку с текущей работой в формате lr_номер (Пример students/k3340/Petrov_Vasya/Lr1).
- Записать в папку отчетные материалы.
- Сделать коммит, описать его адекватно (Пример "был добавлен файл перезентация_петров.pdf"). Набрать команлы git add и git commit -m "название комита".
- Сделать push в Ваш форкнутый репозиторий (git push).