# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 |
![]() |
|
|||
Наша цель - разобраться в этом фреймворке и создать рабочий проект - новую видеошколу. Каждый формулист может стать соавтором новой видеошколы. Каждый участник может написать свои строчки для проекта. И каждый из них получит незаменимый опыт по созданию реального рабочего проекта с использованием современных технологий: Yii, PHP, MySQL, Git, Bootstrap, JavaScript, jQuery, AJAX и многое другое. Отчёт отправил: 30514. Tom Выполнено за 41 мин. [Показать отчёт] Научился: Подготовил инструменты для разработки - web-сервер, редактор кода, git, github. |
|||||
2 | Web - Первый кирпич сайта |
|
|||
На этом уроке мы настроим минимальные версии модулей на нашем OpenServer для дальнейшей работы. Проверим версии apache, php и MySQL. После чего мы поработаем в консоли, создав необходимый минимум. Далее мы проверим работоспособность нашего мини сайта. Отчёт отправил: 30514. Tom Выполнено за 25 мин. [Показать отчёт] Научился: Создал папки проекта school и school/web. Создал файл index.php. Выполнил запуск проекта в веб-браузере с использованием сервера apache и с помощью встроенного сервера в php. |
|||||
3 | Git - Все ходы записываются |
|
|||
На этом уроке мы проинициализиуем локальный git репозиторий в ранее созданной папке нашего проекта school. После чего откроем нашу папку school в PhpStorm для дальнейшей работы уже в более удобной среде разработки. Создадим необходимый файл .gitignore с базовыми правилами и закоммитим наш первый коммит в локальный git репозиторий. Отчёт отправил: 30514. Tom Выполнено за 20 мин. [Показать отчёт] Научился: С помощью команды git init в терминале создал git репозиторий. Средствами IDE добавил в репозиторий файлы index.php и .gitignore и выполнил первый коммит. |
|||||
4 | Composer - Установка пустоты |
|
|||
На этом уроке мы подключим фреймворк Yii через composer в консоли. Научимся получать токен репозитория git. Далее мы приступим к реализации нашего проекта, для начала модифицируем index.php, чтобы задействовать фреймворк Yii. Так же создадим конфигурационный файл для нашего проекта и передадим его как параметр при создании экземпляра веб-приложения Yii. Отчёт отправил: 30514. Tom Выполнено за 1 час. 7 мин. [Показать отчёт] Научился: Установил yii2 через composer, добавил файл config/web.php. |
|||||
5 | Controller - Точка входа программиста |
|
|||
На этом уроке мы создадим первый контроллер, который является точкой входа для нашего веб-приложения. Познакомимся с полезными ссылками и схемами жизненного цикла нашего веб-приложения. Отчёт отправил: 30514. Tom Выполнено за 14 мин. [Показать отчёт] Научился: Создал контроллер SiteController, добавил в него действие actionIndex. |
|||||
6 | Views - Представления начинаются |
2 теста |
|||
На этом уроке мы создадим первое представление для отображения основной странички нашего веб-приложения. Для удобного поиска ошибок мы активируем встроенную в Yii систему отладки. Отчёт отправил: 30514. Tom Выполнено за 26 мин. [Показать отчёт] Научился: Научился включать режим отладки в yii с помощью определения константы YII_DEBUG. Научился создавать главное представление. Добавил представление site/index.php и главное представление layouts/main.php. |
|||||
7 | Codeception - Пошаговое тестирование |
1 тест |
|||
На этом уроке мы установим систему тестирования веб-приложений и создадим несколько тестов имитации поведения гостя на сайте. Отчёт отправил: 30514. Tom Выполнено за 36 мин. [Показать отчёт] Научился: Установил через composer систему для тестирования codeception. Научился создавать acceptance тесты. |
|||||
8 | Bootstrap - Пусть будет красиво! |
|
|||
На этом уроке мы начнём оформление нашего сайта. Для этого мы установим и подключим набор инструментов bootstrap, включающий в себя HTML/CSS шаблоны оформления и JavaScript расширения. Первое что нам необходимо сделать, это добавить верхнее меню. Отчёт отправил: 30514. Tom Выполнено за 51 мин. [Показать отчёт] Научился: С помощью composer установил bootstrap. Используя bootstrap добавил на страницу navbar. Научился добавлять триггеры this->beginPage и т.д. в главное представление layouts/main.php. |
|||||
9 | Menu - Богатый выбор |
|
|||
На прошлом уроке мы создали навигационную панель, на этом уроке мы разместим пункты меню на этой панели. Отчёт отправил: 30514. Tom Выполнено за 21 мин. [Показать отчёт] Научился: Добавил пункты меню Join и Login на навигационную панель. Добавил действия actionJoin, actionLogin в контроллер SiteController. |
|||||
10 | Join/login - Полёт Навигатора |
1 тест |
|||
На этом уроке мы вернёмся к ранее созданным тестам, которые провалились при проверке пунктов меню регистрации и авторизации пользователя. На этом уроке мы устраним проблемы, изза которых тесты не могут завершиться успешно. Отчёт отправил: 30514. Tom Выполнено за 32 мин. [Показать отчёт] Научился: Подключил в файле config/web.php компонент urlManager. Создал файл web/.htaccess, в котором определил правила для преобразования ссылок. Создал представления /site/join и /site/login. |
|||||
11 | Debug - Следы на песке |
1 тест |
|||
На этом уроке мы установим систему отладки в Yii для удобства отлавливания ошибок. После чего мы его подключим, прописав необходимые параметры в конфигурационный файл. Так же продемонстрируем как добавлять собственные логи по типу. Посмотрите инструкцию по установке. Отчёт отправил: 30514. Tom Выполнено за 1 час. 17 мин. [Показать отчёт] Научился: Научился подключать в yii систему отладки. С помощью composer установил yii2-debug. Добавил настройки конфигурации в файл config/web.php. |
|||||
12 | User - Помещение регистратуры |
|
|||
На этом уроке мы займёмся причёсыванием нашего проекта. Создадим необходимые тесты для обоснования наших действий. Для начала вынесем функции join/login в отдельный контроллер. Так же перенесём сопутствующие файлы видов в одноимённую папку. Отчёт отправил: 30514. Tom Выполнено за 21 мин. [Показать отчёт] Научился: Создал контроллер UserController, перенес в него действия actionJoin и actionLogin из контроллера SiteController. Перенес соответствующие представления в папку views/user. Изменил адреса ссылок в меню страницы. |
|||||
13 | Panel - Красивые анкеты |
|
|||
На этом уроке мы займёмся оформлением страничек регистрации и авторизации при помощи набора инструментов bootstrap. Для этого мы доработаем наши представления join/login.php Отчёт отправил: 30514. Tom Выполнено за 16 мин. [Показать отчёт] Научился: Добавил в представления user/join и user/login панель и список полей формы. |
|||||
14 | Model - Модели на подиуме |
|
|||
На этом уроке мы поговорим о моделях, представлениях и связях через контроллер. Для этого мы рассмотрим схему, на основе которой будем писать код в последующих уроках. Отчёт отправил: 30514. Tom Выполнено за 28 мин. [Показать отчёт] Научился: Создал схему моделей UserRecord и UserRecordIdentity для работы с базой данных и моделей UserJoinForm и UserLoginForm для работы с формами ввода. |
|||||
15 | Tests - Обоснование необходимости |
|
|||
На этом уроке мы займёмся обоснованием дальнеших действий через создание тестов. По аналогии напоминает написание ТЗ для программистов. Далее реализуем тесты поведения пользователей на сайте. Отчёт отправил: 30514. Tom Выполнено за 40 мин. [Показать отчёт] Научился: Научился создавать класс для тестирования с помощью команды codecept generate:stepobject acceptance. |
|||||
16 | Steps - Пошаговая инструкция |
|
|||
На этом уроке мы реализуем сгенерированные на прошлом уроке функции для корректной работы созданных, так же на прошлом уроке, тестов. Отчёт отправил: 30514. Tom Выполнено за 25 мин. [Показать отчёт] Научился: Реализовал методы в классе TestUserJoin. Научился заполнять поля формы с помощью метода fillField. |
|||||
17 | Console - Есть ли жизнь в Консоли? |
|
|||
На этом уроке мы создадим консольное приложение на базе Yii и почитаем описание команд. Подключим vendor\autoload.php для корректной работы php yii.php help migrate. Отчёт отправил: 30514. Tom Выполнено за 17 мин. [Показать отчёт] Научился: Научился создавать консольное приложение yii. Добавил конфигурационный файл для консольного приложения. |
|||||
18 | Migration - Архитектура таблицы |
|
|||
На этом уроке мы создадим первую миграцию, опишем в ней структуру таблицы user. Миграции помогают следить за актуальностью схемы базы данных. Отчёт отправил: 30514. Tom Выполнено за 19 мин. [Показать отчёт] Научился: С помощью команды "php yii.php migrate/create create_user_table" создал миграцию для создания таблицы user. |
|||||
19 | DBase - Подключение к Матрице |
2 теста |
|||
На этом уроке мы создадим базу данных в MySQL. После чего создадим конфигурационный файл подключения к БД. Далее запустим миграцию в нашем консольном приложении, для автоматической генерации актуальной структуры таблиц. Отчёт отправил: 30514. Tom Выполнено за 19 мин. [Показать отчёт] Научился: Создал базу данных school. С помощью механизма миграций создал таблицу user. Научился делать откат миграций с помощью команды migrate/down. |
|||||
20 | UserRecord - Очень активная модель |
|
|||
На этом уроке мы создадим модель связи с таблицей пользователей. Добавим в таблицу нашего первого пользователя. После чего перейдём на страничку регистрации и проверим добавился ли пользователь в БД. Так же поизучаем дебаг панель, изучим что происходит при работе с БД. Отчёт отправил: 30514. Tom Выполнено за 31 мин. [Показать отчёт] Научился: Создал модель UserRecord для связи с таблицей user. В действии actionJoin контроллера UserController с помощью класса UserRecord добавил пользователя в таблицу user. |
|||||
21 | Faker - Тысяча фантазёров! |
1 тест |
|||
На этом уроке мы добавим библиотеку Faker для генерации случайных данных при создании случайных пользователей. Для этого мы вначале установим необходимую библиотеку. После чего используем её в наших тестах. Отчёт отправил: 30514. Tom Выполнено за 23 мин. [Показать отчёт] Научился: Научился генерировать случайные данные с помощью библиотеки Faker. |
|||||
22 | UserIdentity - Посторонним В |
|
|||
На этом уроке мы переходим к аутентификации пользователей на нашем сайте. Для этого мы воспользуемся встроенным в Yii интерфейсом IdentityInterface. Немного поэкспериментируем с авторизацией пользователей. Отчёт отправил: 30514. Tom Выполнено за 31 мин. [Показать отчёт] Научился: Создал модель UserIdentity для реализации аутентификации. Применил модель UserIdentity в действии actionLogin контроллера UserController. |
|||||
23 | Logout - Выход из лабиринта |
|
|||
На этом уроке мы реализуем возможность выхода с сайта. Для этого нам понадобиться доработать представление меню, чтобы оно отличалось при авторизованном/неавторизованном пользователе. Так же реализуем метод выхода пользователя с сайта (Logout). Отчёт отправил: 30514. Tom Выполнено за 22 мин. [Показать отчёт] Научился: Изменил меню для зарегистрированного пользователя - вместо Join выводится имя пользователя, вместо Login выводится Logout. Добавил действие actionLogout в контроллер UserController. |
|||||
24 | UserJoinForm - Модель для формы |
|
|||
На этом уроке мы создадим модель для формы регистрации пользователя. После чего мы добавим её использование в нашем представлении join.php Отчёт отправил: 30514. Tom Выполнено за 53 мин. [Показать отчёт] Научился: Создал модель UserJoinForm для регистрации пользователя. С помощью yii добавил форму регистрации в представление /user/join. Передал информацию о модели UserJoinForm в представление через действие actionJoin контроллера UserController. |
|||||
25 | Rules - Валидация без правил |
1 тест |
|||
На этом уроке мы добавим валидацию полей при регистрации пользователя. Также для полей добавим индивидуальные правила. Отчёт отправил: 30514. Tom Выполнено за 22 мин. [Показать отчёт] Научился: Научился добавлять правила для валидации полей формы с помощью метода rules. |
|||||
26 | JoinPost - Вторая сторона модели |
|
|||
На этом уроке мы реализуем вспомогательную функцию, куда перенесём обработку фазы POST запроса нашей формы регистрации пользователей. Так же добавим генерацию начальных данных для первой фазы регистрации пользователей. Отчёт отправил: 30514. Tom Выполнено за 30 мин. [Показать отчёт] Научился: Научился определять наличие POST-данных с помощью Yii::$app->request->isPost. Научился заполнять поля модели формы используя метод load. |
|||||
27 | IfEmailUsed - Почта закрыта |
|
|||
На этом уроке мы добавим проверку существования email в БД перед тем как зарегистрировать пользователя. Проведём эксперименты и отрефакторим нашу проверку. Отчёт отправил: 30514. Tom Выполнено за 28 мин. [Показать отчёт] Научился: Научился создавать новые правила проверки элементов формы и добавлять их в функцию rules. Добавил проверку на существование введенного email в базе данных. |
|||||
28 | HasErrors - Где водятся волшебники? |
|
|||
На этом уроке мы реализуем дополнительную проверку, которая будет генерировать ошибку. После чего добавим проверку наличия ошибок перед тем как проверять на валидность email. Поэкспериментируем с последовательностью самих проверок. Отчёт отправил: 30514. Tom Выполнено за 22 мин. [Показать отчёт] Научился: Научился проверять на наличие ошибок с помощью функции hasErrors. |
|||||
29 | Save - Запись в книгу |
|
|||
На этом уроке мы реализуем добавление данных пользователя в БД, после успешной проверки. Так же добавим редирект на страничку авторизации после успешной регистрации пользователя. Отчёт отправил: 30514. Tom Выполнено за 27 мин. [Показать отчёт] Научился: Создал метод setUserJoinForm, который заполняет модель UserRecord информацией из модели UserJoinForm. Сохранил модель в базе данных с помощью метода save. |
|||||
30 | UserLoginForm - Модель на входе |
|
|||
На этом уроке мы реализуем форму авторизации пользователей. Создадим модель UserLoginForm и добавим правила заполнения полей. Отчёт отправил: 30514. Tom Выполнено за 20 мин. [Показать отчёт] Научился: Создал модель UserLoginForm, в которой определил поля формы и правила в методе rules. Изменил действие actionLogin в контроллере UserController и представление /user/login.php для использования информации из модели UserLoginForm. |
|||||
31 | IfEmailNotFound - На деревню дедушке |
|
|||
На этом уроке мы реализуем проверку почтового ящика при авторизации пользователя, а зарегистрирован ли он. Так же настроим контроллер для корректной работы проверки. Отчёт отправил: 30514. Tom Выполнено за 35 мин. [Показать отчёт] Научился: Реализовал проверку на существование пользователя с указанным e-mail адресом. Выполнил поиск в базе по введенному e-mail. Если пользовател найден, то выполняется вход на сайт и показывается главная страница. |
|||||
32 | IfPasswordWrong - Пароль? Пароль! Проходи. |
|
|||
На этом уроке мы добавим ещё одну валидацию при авторизации пользователя, а именно вводимый им пароль. Посмотрим логи запросов в БД и запустим тестирование. Отчёт отправил: 30514. Tom Выполнено за 30 мин. [Показать отчёт] Научился: Реализовал проверку на правильность введенного пароля. Для этого в модели UserLoginForm в методе rules для поля password добавил правило errorIfPasswordWrong. Создал метод errorIfPasswordWrong, который проверяет корректность пароля. |
|||||
33 | Refactoring - Нет дубликатам! |
|
|||
На этом уроке мы займёмся рефакторингом дублирующего кода, выполняющего одно и тоже на протяжении выполнения одной задачи. Отчёт отправил: 30514. Tom Выполнено за 14 мин. [Показать отчёт] Научился: Создал в классе UserLoginForm свойство private $userRecord, которое инициализируется во время проверки в методе errorIfEmailNotFound и далее используется в методах errorIfPasswordWrong и login. |
|||||
34 | Test - Запуск функциональных тестов |
|
|||
На этом уроке мы создадим функциональный тест. Но для корректной его работы, нам понадобиться провести несколько очень важных манипуляций. Отчёт отправил: 30514. Tom Выполнено за 39 мин. [Показать отчёт] Научился: Настроил yii для запуска функциональных тестов. Создал функциональный тест PasswordHasherTest, который делает запрос к базе данных и проверяет, что пользователя с id = 1 зовут John. |
|||||
35 | PasswordIsHashed - Покажите-ка ваш хэш |
|
|||
На этом уроке мы реализуем тестирование на корректность хешированных паролей перед тем как они сохраняются в БД. Для начала нам понадобиться создать дополнительную функцию установки пароля в UserRecord(). После чего мы приступим к созданию тестов. Отчёт отправил: 30514. Tom Выполнено за 45 мин. [Показать отчёт] Научился: Научился сверять пароль с его хешем с помощью метода validatePassword класса yii\base\Security. |
|||||
36 | Security - Кручу-верчу-захэшировать хочу! |
|
|||
На этом уроке мы реализуем хеширование паролей перед тем как их сохранять в базу данных. Для начала нужно очистить все аккаунты пользователей, так как они содержат пароли в явном виде. Отчёт отправил: 30514. Tom Выполнено за 22 мин. [Показать отчёт] Научился: Научился создавать хеш пароля с помощью метода generatePasswordHash класса yii\base\Security. |
|||||
37 | Hash - Как правильно солить пароли |
|
|||
На этом уроке мы поговорим о вариантах хеширования паролей пользователей для дополнительной безопасности. Посмотрим, сколько времени занимает хеширование пароля, воспользовавшись встроенной системой профилирования. Отчёт отправил: 30514. Tom Выполнено за 30 мин. [Показать отчёт] Научился: Научился задавать стоимость хеширования с помощью параметра $cost в методе generatePasswordHash. Научился выполнять профилирование с помощью методов Yii::beginProfile и Yii::endProfile. |
|||||
38 | Remember me - Печенька на память |
|
|||
На этом уроке мы поговорим о галочке «Запомнить меня» для авторизации на месяц — чтобы сайт не просил повторно вводить логин/пароль даже после закрытия/открытия браузера. Отчёт отправил: 30514. Tom Выполнено за 22 мин. [Показать отчёт] Научился: Добавил в форму UserLoginForm галочку "Запомнить меня" и реализовал запоминание пользователя, выполнившего вход на сайт. |
|||||
39 | Authokey - Ключи в сейфе |
|
|||
На этом уроке мы реализуем более безопасный способ автоматической авторизации на сайте. Для этого мы создадим отдельное поле 'authokey', в нашей БД, для автологина. Отчёт отправил: 30514. Tom Выполнено за 21 мин. [Показать отчёт] Научился: С помощью механизма миграций добавил в таблицу новый столбец authokey и использовал его для входа пользователя на сайт. |
|||||
40 | REFRESH - 40 МГНОВЕНИЙ ОПЫТА |
|
|||
На этом финальном уроке тебе предстоит повторить весь курс ещё раз. Да, ты не ослышался - выполнить все шаги по созданию этого проекта. Чтобы было удобнее - скачай план уроков всего курса. Уверен, ты сможешь всё сделать самостоятельно, причём, значительно быстрее. Лучше всего это сделать на другом компьютере. Отчёт отправил: 30514. Tom Выполнено за 5 час. 52 мин. [Показать отчёт] Научился: Выполнил весь курс с нуля. Создал новый виртуальный хост school2.local, установил yii и все необходимые библиотеки. Идея повторного выполнения курса мне понравилась. Это помогло мне лучше понять как взаимодействуют между собой различные элементы фреймворка yii. |
|||||
Итого: 40 видеоуроков |
7 час. 42 мин. 9 тестов |
5 чел. | |||
Финалисты: Иван Воронин, Tekashnik, Семен, Александр, Tom . |