# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 |
![]() |
|
|||
Наша цель - разобраться в этом фреймворке и создать рабочий проект - новую видеошколу. Каждый формулист может стать соавтором новой видеошколы. Каждый участник может написать свои строчки для проекта. И каждый из них получит незаменимый опыт по созданию реального рабочего проекта с использованием современных технологий: Yii, PHP, MySQL, Git, Bootstrap, JavaScript, jQuery, AJAX и многое другое. Отчёт отправил: 21753. Николай Выполнено за 47 мин. [Показать отчёт] Научился: Установил PHP Storm, OpenServer, git. |
|||||
2 | Web - Первый кирпич сайта |
|
|||
На этом уроке мы настроим минимальные версии модулей на нашем OpenServer для дальнейшей работы. Проверим версии apache, php и MySQL. После чего мы поработаем в консоли, создав необходимый минимум. Далее мы проверим работоспособность нашего мини сайта. Отчёт отправил: 21753. Николай Выполнено за 13 мин. [Показать отчёт] Научился: Вспомнил как работать в консоли |
|||||
3 | Git - Все ходы записываются |
|
|||
На этом уроке мы проинициализиуем локальный git репозиторий в ранее созданной папке нашего проекта school. После чего откроем нашу папку school в PhpStorm для дальнейшей работы уже в более удобной среде разработки. Создадим необходимый файл .gitignore с базовыми правилами и закоммитим наш первый коммит в локальный git репозиторий. Отчёт отправил: 21753. Николай Выполнено за 14 мин. [Показать отчёт] Научился: Установил отдельный клиент для git. Сложности: Забыл пароль от git |
|||||
4 | Composer - Установка пустоты |
|
|||
На этом уроке мы подключим фреймворк Yii через composer в консоли. Научимся получать токен репозитория git. Далее мы приступим к реализации нашего проекта, для начала модифицируем index.php, чтобы задействовать фреймворк Yii. Так же создадим конфигурационный файл для нашего проекта и передадим его как параметр при создании экземпляра веб-приложения Yii. Отчёт отправил: 21753. Николай Выполнено за 1 день 6 час. 46 мин. [Показать отчёт] Научился: Долго не мог выполнить команду composer global require "fxp/composer-asset-plugin:*" После обновления OpenServer команду получилось выполнить. |
|||||
5 | Controller - Точка входа программиста |
|
|||
На этом уроке мы создадим первый контроллер, который является точкой входа для нашего веб-приложения. Познакомимся с полезными ссылками и схемами жизненного цикла нашего веб-приложения. Отчёт отправил: 21753. Николай Выполнено за 38 мин. [Показать отчёт] Научился: Пришлось повторить все прошлые уроки с нуля. Настроил Git, создал новый проект в PhpStorm, скачал через composer yii2, поменял настройки OpenServer. И только после этого получилось запустить свой первый сайт на YII. Сложности: Побороть лень. |
|||||
6 | Views - Представления начинаются |
2 теста |
|||
На этом уроке мы создадим первое представление для отображения основной странички нашего веб-приложения. Для удобного поиска ошибок мы активируем встроенную в Yii систему отладки. Отчёт отправил: 21753. Николай Выполнено за 18 мин. [Показать отчёт] Научился: Научился создавать представление. Познакомился с системой отладки |
|||||
7 | Codeception - Пошаговое тестирование |
1 тест |
|||
На этом уроке мы установим систему тестирования веб-приложений и создадим несколько тестов имитации поведения гостя на сайте. Отчёт отправил: 21753. Николай Выполнено за 1 час. 2 мин. [Показать отчёт] Научился: Создал свой первый тест который с успехом провалил. На втором шаге появилась ошибка: Fail Element located either by name, CSS or XPath element with 'h1' was not found. Может быть этот связано с тем, что я использую 82 порт. Сложности: Успешно завершить тестирование |
|||||
8 | Bootstrap - Пусть будет красиво! |
|
|||
На этом уроке мы начнём оформление нашего сайта. Для этого мы установим и подключим набор инструментов bootstrap, включающий в себя HTML/CSS шаблоны оформления и JavaScript расширения. Первое что нам необходимо сделать, это добавить верхнее меню. Отчёт отправил: 21753. Николай Выполнено за 34 мин. [Показать отчёт] Научился: Научился устанавливать bootstrap и выводить navbar |
|||||
9 | Menu - Богатый выбор |
|
|||
На прошлом уроке мы создали навигационную панель, на этом уроке мы разместим пункты меню на этой панели. Отчёт отправил: 21753. Николай Выполнено за 17 мин. [Показать отчёт] Научился: Добавил пункты меню. |
|||||
10 | Join/login - Полёт Навигатора |
1 тест |
|||
На этом уроке мы вернёмся к ранее созданным тестам, которые провалились при проверке пунктов меню регистрации и авторизации пользователя. На этом уроке мы устраним проблемы, изза которых тесты не могут завершиться успешно. Отчёт отправил: 21753. Николай Выполнено за 35 мин. [Показать отчёт] Научился: Сделал views для страниц login и join. Выполнил тесты которые прошли без ошибок. |
|||||
11 | Debug - Следы на песке |
1 тест |
|||
На этом уроке мы установим систему отладки в Yii для удобства отлавливания ошибок. После чего мы его подключим, прописав необходимые параметры в конфигурационный файл. Так же продемонстрируем как добавлять собственные логи по типу. Посмотрите инструкцию по установке. Отчёт отправил: 21753. Николай Выполнено за 12 час. 0 мин. [Показать отчёт] Научился: Подключил модуль отладки к своему проекту |
|||||
12 | User - Помещение регистратуры |
|
|||
На этом уроке мы займёмся причёсыванием нашего проекта. Создадим необходимые тесты для обоснования наших действий. Для начала вынесем функции join/login в отдельный контроллер. Так же перенесём сопутствующие файлы видов в одноимённую папку. Отчёт отправил: 21753. Николай Выполнено за 17 мин. [Показать отчёт] Научился: Перенес join и login в отдельный контроллер. |
|||||
13 | Panel - Красивые анкеты |
|
|||
На этом уроке мы займёмся оформлением страничек регистрации и авторизации при помощи набора инструментов bootstrap. Для этого мы доработаем наши представления join/login.php Отчёт отправил: 21753. Николай Выполнено за 9 мин. [Показать отчёт] Научился: Добавил оформление страницы login и join |
|||||
14 | Model - Модели на подиуме |
|
|||
На этом уроке мы поговорим о моделях, представлениях и связях через контроллер. Для этого мы рассмотрим схему, на основе которой будем писать код в последующих уроках. Отчёт отправил: 21753. Николай Выполнено за 15 мин. [Показать отчёт] Научился: Нарисовал схему с помощью сайта draw.io |
|||||
15 | Tests - Обоснование необходимости |
|
|||
На этом уроке мы займёмся обоснованием дальнеших действий через создание тестов. По аналогии напоминает написание ТЗ для программистов. Далее реализуем тесты поведения пользователей на сайте. Отчёт отправил: 21753. Николай Выполнено за 28 мин. [Показать отчёт] Научился: Создал тест |
|||||
16 | Steps - Пошаговая инструкция |
|
|||
На этом уроке мы реализуем сгенерированные на прошлом уроке функции для корректной работы созданных, так же на прошлом уроке, тестов. Отчёт отправил: 21753. Николай Выполнено за 19 час. 17 мин. [Показать отчёт] Научился: Дописал тест Сложности: Выполнить тесты корректно. Устал бороться с ошибками( |
|||||
17 | Console - Есть ли жизнь в Консоли? |
|
|||
На этом уроке мы создадим консольное приложение на базе Yii и почитаем описание команд. Подключим vendor\autoload.php для корректной работы php yii.php help migrate. Отчёт отправил: 21753. Николай Выполнено за 16 мин. [Показать отчёт] Научился: создал yii.php |
|||||
18 | Migration - Архитектура таблицы |
|
|||
На этом уроке мы создадим первую миграцию, опишем в ней структуру таблицы user. Миграции помогают следить за актуальностью схемы базы данных. Отчёт отправил: 21753. Николай Выполнено за 2 час. 40 мин. [Показать отчёт] Научился: Генерировать файл миграции |
|||||
19 | DBase - Подключение к Матрице |
2 теста |
|||
На этом уроке мы создадим базу данных в MySQL. После чего создадим конфигурационный файл подключения к БД. Далее запустим миграцию в нашем консольном приложении, для автоматической генерации актуальной структуры таблиц. Отчёт отправил: 21753. Николай Выполнено за 14 мин. [Показать отчёт] Научился: Выполнять миграции |
|||||
20 | UserRecord - Очень активная модель |
|
|||
На этом уроке мы создадим модель связи с таблицей пользователей. Добавим в таблицу нашего первого пользователя. После чего перейдём на страничку регистрации и проверим добавился ли пользователь в БД. Так же поизучаем дебаг панель, изучим что происходит при работе с БД. Отчёт отправил: 21753. Николай Выполнено за 21 мин. [Показать отчёт] Научился: Добавил первую запись в таблицу |
|||||
21 | Faker - Тысяча фантазёров! |
1 тест |
|||
На этом уроке мы добавим библиотеку Faker для генерации случайных данных при создании случайных пользователей. Для этого мы вначале установим необходимую библиотеку. После чего используем её в наших тестах. Отчёт отправил: 21753. Николай Выполнено за 18 мин. [Показать отчёт] Научился: Установил Faker. Проверил на базе |
|||||
22 | UserIdentity - Посторонним В |
|
|||
На этом уроке мы переходим к аутентификации пользователей на нашем сайте. Для этого мы воспользуемся встроенным в Yii интерфейсом IdentityInterface. Немного поэкспериментируем с авторизацией пользователей. Отчёт отправил: 21753. Николай Выполнено за 43 мин. [Показать отчёт] Научился: Создавать модель UserIdentity |
|||||
23 | Logout - Выход из лабиринта |
|
|||
На этом уроке мы реализуем возможность выхода с сайта. Для этого нам понадобиться доработать представление меню, чтобы оно отличалось при авторизованном/неавторизованном пользователе. Так же реализуем метод выхода пользователя с сайта (Logout). Отчёт отправил: 21753. Николай Выполнено за 1 час. 2 мин. [Показать отчёт] Научился: Сделал выходи из программы. Сложности: Долго искал ошибку. Нашел только после того как пересмотрел прошлый урок |
|||||
24 | UserJoinForm - Модель для формы |
|
|||
На этом уроке мы создадим модель для формы регистрации пользователя. После чего мы добавим её использование в нашем представлении join.php Отчёт отправил: 21753. Николай Выполнено за 42 мин. [Показать отчёт] Научился: Создал форму для регистрации |
|||||
25 | Rules - Валидация без правил |
1 тест |
|||
На этом уроке мы добавим валидацию полей при регистрации пользователя. Также для полей добавим индивидуальные правила. Отчёт отправил: 21753. Николай Выполнено за 36 мин. [Показать отчёт] Научился: Создал валидацию форм |
|||||
26 | JoinPost - Вторая сторона модели |
|
|||
На этом уроке мы реализуем вспомогательную функцию, куда перенесём обработку фазы POST запроса нашей формы регистрации пользователей. Так же добавим генерацию начальных данных для первой фазы регистрации пользователей. Отчёт отправил: 21753. Николай Выполнено за 50 мин. [Показать отчёт] Научился: создал автозаполнение полей |
|||||
27 | IfEmailUsed - Почта закрыта |
|
|||
На этом уроке мы добавим проверку существования email в БД перед тем как зарегистрировать пользователя. Проведём эксперименты и отрефакторим нашу проверку. Отчёт отправил: 21753. Николай Выполнено за 49 мин. [Показать отчёт] Научился: Добавил проверку на email |
|||||
28 | HasErrors - Где водятся волшебники? |
|
|||
На этом уроке мы реализуем дополнительную проверку, которая будет генерировать ошибку. После чего добавим проверку наличия ошибок перед тем как проверять на валидность email. Поэкспериментируем с последовательностью самих проверок. Отчёт отправил: 21753. Николай Выполнено за 18 мин. [Показать отчёт] Научился: Реализовал дополнительную проверку |
|||||
29 | Save - Запись в книгу |
|
|||
На этом уроке мы реализуем добавление данных пользователя в БД, после успешной проверки. Так же добавим редирект на страничку авторизации после успешной регистрации пользователя. Отчёт отправил: 21753. Николай Выполнено за 1 час. 29 мин. [Показать отчёт] Научился: Исправил ошибки в тестах. |
|||||
30 | UserLoginForm - Модель на входе |
|
|||
На этом уроке мы реализуем форму авторизации пользователей. Создадим модель UserLoginForm и добавим правила заполнения полей. Отчёт отправил: 21753. Николай Выполнено за 43 мин. [Показать отчёт] Научился: Для смены названия заголовков полей ввода я добавил в модель функцию: public function attributeLabels() { return [ 'email' => 'Your email address', 'password' => 'Пароль', ]; } |
|||||
31 | IfEmailNotFound - На деревню дедушке |
|
|||
На этом уроке мы реализуем проверку почтового ящика при авторизации пользователя, а зарегистрирован ли он. Так же настроим контроллер для корректной работы проверки. Отчёт отправил: 21753. Николай Выполнено за 21 мин. [Показать отчёт] Научился: Добавил проверку почтового ящика |
|||||
32 | IfPasswordWrong - Пароль? Пароль! Проходи. |
|
|||
На этом уроке мы добавим ещё одну валидацию при авторизации пользователя, а именно вводимый им пароль. Посмотрим логи запросов в БД и запустим тестирование. Отчёт отправил: 21753. Николай Выполнено за 14 мин. [Показать отчёт] Научился: Добавил проверку пароля |
|||||
33 | Refactoring - Нет дубликатам! |
|
|||
На этом уроке мы займёмся рефакторингом дублирующего кода, выполняющего одно и тоже на протяжении выполнения одной задачи. Отчёт отправил: 21753. Николай Выполнено за 17 мин. [Показать отчёт] Научился: Вчера очень долго искал ошибки. Выходила пустая страница при нажатии на login. Тесты стопорились на 12 тесте. Ошибку нашел - опечатка в названии функции и пропустил целую сточку кода. Всю ночь снилось как ищу ошибки в коде. |
|||||
34 | Test - Запуск функциональных тестов |
|
|||
На этом уроке мы создадим функциональный тест. Но для корректной его работы, нам понадобиться провести несколько очень важных манипуляций. Отчёт отправил: 21753. Николай Выполнено за 24 мин. [Показать отчёт] Научился: Написал функциональный тест |
|||||
35 | PasswordIsHashed - Покажите-ка ваш хэш |
|
|||
На этом уроке мы реализуем тестирование на корректность хешированных паролей перед тем как они сохраняются в БД. Для начала нам понадобиться создать дополнительную функцию установки пароля в UserRecord(). После чего мы приступим к созданию тестов. Отчёт отправил: 21753. Николай Выполнено за 31 мин. [Показать отчёт] Научился: Реализовал тестирование на корректность хеширование паролей |
|||||
36 | Security - Кручу-верчу-захэшировать хочу! |
|
|||
На этом уроке мы реализуем хеширование паролей перед тем как их сохранять в базу данных. Для начала нужно очистить все аккаунты пользователей, так как они содержат пароли в явном виде. Отчёт отправил: 21753. Николай Выполнено за 14 мин. [Показать отчёт] Научился: Научился хешировать пароли |
|||||
37 | Hash - Как правильно солить пароли |
|
|||
На этом уроке мы поговорим о вариантах хеширования паролей пользователей для дополнительной безопасности. Посмотрим, сколько времени занимает хеширование пароля, воспользовавшись встроенной системой профилирования. Отчёт отправил: 21753. Николай Выполнено за 12 мин. [Показать отчёт] Научился: прочитал статью хеширования паролей |
|||||
38 | Remember me - Печенька на память |
|
|||
На этом уроке мы поговорим о галочке «Запомнить меня» для авторизации на месяц — чтобы сайт не просил повторно вводить логин/пароль даже после закрытия/открытия браузера. Отчёт отправил: 21753. Николай Выполнено за 14 мин. [Показать отчёт] Научился: Добавил функционал запоминания пользователя |
|||||
39 | Authokey - Ключи в сейфе |
|
|||
На этом уроке мы реализуем более безопасный способ автоматической авторизации на сайте. Для этого мы создадим отдельное поле 'authokey', в нашей БД, для автологина. Отчёт отправил: 21753. Николай Выполнено за 18 мин. [Показать отчёт] Научился: Вот и закончилась первая часть по YII2. Осталось выполнить последнее задание. |
|||||
40 | REFRESH - 40 МГНОВЕНИЙ ОПЫТА |
|
|||
На этом финальном уроке тебе предстоит повторить весь курс ещё раз. Да, ты не ослышался - выполнить все шаги по созданию этого проекта. Чтобы было удобнее - скачай план уроков всего курса. Уверен, ты сможешь всё сделать самостоятельно, причём, значительно быстрее. Лучше всего это сделать на другом компьютере. |
|||||
Итого: 40 видеоуроков |
7 час. 42 мин. 9 тестов |
5 чел. | |||
Финалисты: Иван Воронин, Tekashnik, Семен, Александр, Tom . |