C# обучение видео

Формула программиста

основатель — Волосатов Евгений Витольдович

Клуб формулистов - Ежемесячная подписка

Вступление в Клуб Формулистов на выгодных условиях для НОВЫХ участников.

После взноса  999  499 руб. вы получите подписку
в Клуб Формулистов на 30 дней и 256 байт для быстрого старта.
Байты используются для открытия более одного урока в день, по 50 байт за урок.

Стоимость 1 дня за первый месяц: всего 16 рублей.

Первый взнос - 499 руб./30 дней.

Через 30 дней будет списано 3,000 2,400 руб.
за продление подписки в Клуб на 30 дней + подарок 512 байт.

Так будет продолжаться каждые 30 дней, пока вы не отмените подписку.
Средства будет автоматически считываться с вашей карты.
Вы в любой момент сможете отказаться от продления Клуба.

Только ДО КОНЦА НЕДЕЛИ -
-50% скидка на первый взнос, всего 499 (вместо 999) рублей!
-20% скидка на ЕЖЕМЕСЯЧНЫЙ платёж!
Всего 2400 руб/месяц (вместо 3000 руб/месяц), или 80 руб./день - цена чашки кофе.


Стоимость 1 дня: 80 руб.

Хочу вступить!

Также есть другие варианты оплаты участия в КФ:

Билет в клуб формулистов на ...
30+ дней | 60 дней | 150 дней | 380 дней | 1000 дней

Внимание!
Стоимость участия в Клубе формулистов увеличивается 1 числа каждого месяца на 100 рублей.
При оформления подписки стоимость остаётся постоянной, пока подписка не будет отменена.







Первый взнос - 499 руб./30 дней + 500 байт.
Последующие взносы - 3,000 2400 руб./месяц + 512 байт.



Список уроков | фото | видео

# Название видеоурока Видео / Тесты Решило Рейтинг Доступ
1 FREE Мы начинаем ASP.NET с MVC 00:06:08
125 чел. ★ 4.8 Done
  На этом уроке мы создадим тестовый проект
с использованием технологии ASP.NET на MVC шаблоне
и рассмотрим структуру проекта.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 11 мин. [Показать отчёт]
Научился: Действительно просто. Поигрался ещё немного с CSS. Только неудобно, что нет графического дизайнера: надо тестировать изменения в браузере, потом искать классы в открытом в VS файле с CSS... Неудобно. 
2 Выбор темы для проекта 00:02:35
105 чел. ★ 4.8 Done
  На этом уроке мы обсудим, какой сайт будем делать.

Отчёт отправил: 10080. FireWolf Выполнено за 54 мин. [Показать отчёт]
Научился: Схема сайта ithappens.me: .../ - главная страница, последние истории .../best - лучшие истории .../random - случайные истории .../story/add - добавить историю .../tags - теги историй .../tags/... - разные теги .../page/... - разные страницы Гм... История для сайта историй... Ну скажем было дело, давно в парке, где собирались анимешники, один знакомый менялся с другими анимешниками кассетами, а тут подъехала милиция и его забрали в отделение, так как подумали, что он нелегально фильмами торгует. В отделении поставили пару кассет, увидели, что там мультики и отпустили восвояси. Знакомый был рад, что милиционеры не стали смотреть остальные кассеты, так как там были и аниме таких жанров, что в общественных местах показывать не рекомендуется :) 
Сложности: Вспомнить какую-нибудь историю. 
3 Создание схемы проекта 00:06:41
99 чел. ★ 4.7 Done
  На этом уроке мы ещё раз просмотрим сайт,
и выберем страницы, которые будем создавать.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 23 мин. [Показать отчёт]
Научился: .../                                  - главная страница, последние истории ../page/index .../story/best                  - лучшие истории .../story/random            - случайные истории .../story/add                  - добавить историю .../story/number/12345 - показать историю 12345 Гм... История для сайта историй... Ну скажем было дело, давно в парке, где собирались анимешники, один знакомый менялся с другими анимешниками кассетами, а тут подъехала милиция и его забрали в отделение, так как подумали, что он нелегально фильмами торгует. В отделении поставили пару кассет, увидели, что там мультики и отпустили восвояси. Знакомый был рад, что милиционеры не стали смотреть остальные кассеты, так как там были и аниме таких жанров, что в общественных местах показывать не рекомендуется :) 
4 Создание пустых страниц 00:10:50
1 тест
93 чел. ★ 4.9 Done
  На этом уроке мы создадим новый пустой проект,
добавим нужные контроллеры

Отчёт отправил: 10080. FireWolf Выполнено за 2 час. 9 мин. [Показать отчёт]
Научился: Действительно всё не так сложно и очень интересно. 
5 Создание модели Story 00:12:38
75 чел. ★ 4.9 Done
  На этом уроке мы создадим модель Story.
В этой модели будят вся логика работы с историями.

Отчёт отправил: 10080. FireWolf Выполнено за 4 час. 12 мин. [Показать отчёт]
Научился: Здорово! Даже почти понял, что и как работает :) Пока не дошли до взаимодействия с базой, сделал простенькое хранение историй в Dictionary<int, (string, string)>, который хранит ValueTuple из C#7, и написал метод, который при инициализации модели забивает через Add туда несколько историй (заодно и метод для добавления готов). Также сделал метод Random, который тасует истории и вызывается из View ../story/random перед выводом наполнения страницы. Пока не понял, как начальный Index только заполнить. Что-то перенапраление из PageController.Index() на экземлярный StoryController.Random() оставляет страницу с наполнением по умолчанию. Надеюсь, дальше этот вопрос осветят. 
6 Формирование меню 00:10:46
74 чел. ★ 5 Done
  На этом уроке мы сформируем навигационное меню в шапке нашего сайта.
Отчёт отправил: 10080. FireWolf Выполнено за 7 час. 48 мин. [Показать отчёт]
Научился: Добавил меню "About". Разбираюсь всё лучше и лучше. Вызывает сомнение отказ в уроке от самостоятельного пункта меню "Random" и перенаправление на  View "Number". У них же разное предназначение: Random по логике выводит случайную историю из базы, а Number выводит конкретную историю по номеру, разве не так? 
7 Установка сервера MySQL 00:08:39
72 чел. ★ 4.8 Done
  На этом уроке мы установим MySQL Community Server
и программу HeidiSQL для подключения к нему.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 25 мин. [Показать отчёт]
Научился: Устанавливать MySQL и HeidiSQL к уже установленным MSSQL и MSSMS я не стал. Буду работать с ними. 
8 Схема базы данных 00:15:58
72 чел. ★ 4.9 Done
  На этом уроке мы создадим базу данных для нашего проекта,
подготовим схему таблицы и напишем SQL запрос для её создания.
Отчёт отправил: 10080. FireWolf Выполнено за 2 час. 39 мин. [Показать отчёт]
Научился: Так как делал в MSSQL, то научился создавать базу данных через sqlcmd :) но создавать таблицу с колонками через консоль я поленился. Зачем, если есть MSSMS? По-моему это тема больше для отдельного курса по SQL. База данных позволяет хранить, выводить и добавлять истории с указанием заголовка, автора и времени добавления истории. 
9 Создание SQL-запросов 00:20:44
70 чел. ★ 4.9 Done
  На этом уроке мы составим список задач для нашей базы
и составим SQL запросы для решения каждой задачи.
Все запросы протестируем в SQL-консоли.
Отчёт отправил: 10080. FireWolf Выполнено за 7 час. 2 мин. [Показать отчёт]
Научился: Пришлось повозиться, чтобы найти способ сохранять русский текст в базу. Попутно выяснилось, что тип text/ntext в MSSQL является устаревшим и вместо него рекомендуется использовать varchar/nvarchar(MAX). Ещё нашёл альтернативу sqlcmd - написанную на питоне mssql-cli которая подставляет команды и красиво форматирует вывод. Ну и нашёл сервис для конвертации команд MySQL в MSSQL :) 
Сложности: Немного погуглить, чтобы решить проблему с русским языком в записях базы и заставить себя позаниматься командной строкой, а не только в MSSMS всё сделать :) 
10 Подключение к базе данных 00:25:51
66 чел. ★ 4.9 Done
  Мы достигли Экватора нашего проекта!
На этом уроке мы подключим наш проект
к созданной базе данных на MySQL.
Отчёт отправил: 10080. FireWolf Выполнено за 4 час. 54 мин. [Показать отчёт]
Научился: Делал для MSSQL, так что было интересно переделывать под него показанные команды для MySQL. Вроде даже разобрался как увязываются Model, View и Controller и сделал вывод на индекс и на Last Story  последней истории и случайной истории на Random. 
11 Работа над ошибками 00:36:57
59 чел. ★ 4.9 Done
  На этом уроке мы создадим механизм отлова ошибок
при работе с базой данных и передачи их клиенту.
Отчёт отправил: 10080. FireWolf Выполнено за 3 час. 46 мин. [Показать отчёт]
Научился: Мне кажется, что для хранения информации об ошибках нужен отдельный класс, чтобы не хранить в классе SQL запросов ошибки из других классов (например ошибки получения данных из результата запроса). 
12 Запуск модели Story 00:35:22
55 чел. ★ 4.9 Done
  На этом уроке мы запустим модель Story -
допишем методы Number() и Random(),
организуем ещё одну проверку ошибок.
Отчёт отправил: 10080. FireWolf Выполнено за 12 час. 58 мин. [Показать отчёт]
Научился: Очень интересно, как получается испольщовать логику построения программы на C# в создании веб-страницы. Чувствую, что по завершении курса смогу уже попробовать сделать свою страничку :) 
13 Что такое SQL-инъекция 00:25:24
54 чел. ★ 4.9 Done
  На этом уроке мы сделаем бекап базы данных,
затем продемонстрируем «взлом» страницы
посредством SQL-инъекции, покажем,
как от этого защититься и потом
восстановим базу данных.

Отчёт отправил: 10080. FireWolf Выполнено за 6 час. 54 мин. [Показать отчёт]
Научился: Интересно, что у меня при таком же, как в уроке, запросе, в ответ просто приходит ошибка, а не история по номеру в начале "инъекции". Видимо, какая-то разница в реализации MySQL и MSSQL. Конечно, если н епредусмотреть защиту от SQL-инъекций, то возможности для злоумышленника поистине безграничны :) Интересно почитать на эту тему, потому что подозреваю, что одной такой предосторожности, как в уроке, явно недостаточно. 
14 Рефакторинг модели Story 00:05:28
53 чел. ★ 4.9 Done
  На этом уроке мы сделаем небольшой рефакторинг класса Story.
Отчёт отправил: 10080. FireWolf Выполнено за 34 мин. [Показать отчёт]
Научился: Проблемы с затенением id у меня не возникло, так как я свойства всегда пишу с большой буквы. А вместо дополнительной перегрузки вынесенного метода получения строки я просто id обозначил как необязательный аргумент со значением по умолчанию. 
15 Работа со списком историй 00:24:25
53 чел. ★ 5 Done
  На этом уроке мы сделаем вывод списка историй на главной странице.
Отчёт отправил: 10080. FireWolf Выполнено за 3 час. 12 мин. [Показать отчёт]
Научился: Да, волшебство просто. Особенно нравятся вызовы функций из htmls кода. Я, конечно, в этом ещё слабо разбираюсь, но если нам понадобился класс, содержащий список с экземплярами этого самого класса, то, возможно, это является показанием к использованию индексатора? 
16 Добавление истории 00:43:20
50 чел. ★ 4.9 Done
  На этом уроке мы реализуем отправку истории и добавление её в базу данных.
Мы рассмотрим возможные ошибки, которые могут возникнуть при этом.
Отчёт отправил: 10080. FireWolf Выполнено за 10 час. 52 мин. [Показать отчёт]
Научился: Научился добавлять данные из формы на странице в базу. Вообще, очень познавательно. Интересно попробовать переписать это под Entity Framework - наверное это предпочтительный способ создания сайта, но всегда полезно узнать, как оно работает, когда прописываешь всё руками. 
Сложности: Немного пришлось поискать, как получать Id последней совершённой записи в базу в MSSQL, так как в отличие от MySQL здесь нет удобной функции получения Id псоледней записи, а надо прописывать получение сразу в строке добавления записи в базу, причём существует несколько способов, каждый со своими особенностями. Microsoft же... 
17 Валидация данных 00:23:09
50 чел. ★ 5 Done
  На этом уроке мы реализуем проверку полей формы при отправке истории.
Обсудим регулярное выражение для проверки адреса электропочты.
Отчёт отправил: 10080. FireWolf Выполнено за 3 час. 5 мин. [Показать отчёт]
Научился: Интересно про встроенную валидацию. Вотрегулярные выражения надо подучить - сильно хитрая штука и просто так не даётся. 
18 Оформление сайта 00:46:07
49 чел. ★ 4.8 Done
  На этом уроке мы займемся внешним видом нашего сайта,
будем оформлять страницы, используя возможности bootstrap 3.
Отчёт отправил: 10080. FireWolf Выполнено за 1 день 6 час. 12 мин. [Показать отчёт]
Научился: Наверное из-за того, что у меня на чердаке в отличие от урока есть дополнительная ссылка "About", то при ширине окна браузера болье 1200px всё равно слетает вертикальное расположение элементов формы. 
Сложности: Так как в CSS я разбираюсь очень слабо, то найти решение проблемы пока не смог. 
19 Размещение проекта в Интернете 00:33:42
45 чел. ★ 4.8 Done
  В этом уроке мы зарегистрируемся на хостинге
и разместим свой проект в Интернете, наконец-таки!

Отчёт отправил: 10080. FireWolf Выполнено за 6 час. 8 мин. [Показать отчёт]
Научился: Повторил процесс регистрации на хостинге и загрузку базы данных и сайта :) http://firewolf-001-site1.itempurl.com/ 
Сложности: Как обычно, из-за расхождения версий пришлось заливать базу данных в виде скрипта. И ТоталКоммандер коннектился к ФТП, но останавливался на процессе отображения папки, так что пришлось через сервер архивом закидывать. 
20 Отказ от статика 00:13:42
46 чел. ★ 4.7 Done
  Нам придётся отказаться от статичного класса базы данных,
потому что статичный класс продолжает существование
даже при новых обращениях к нему с новой страницы.

Отчёт отправил: 10080. FireWolf Выполнено за 2 час. 28 мин. [Показать отчёт]
Научился: Не знаю, может у меня ошибка, но если делать именно по уроку и просто сделать класс работы с SQL экземплярным, то появляются ошибки с добавлением новых записей, так как требуется конструктор без параметров. Попробовал держать пустой конструктор, но тогда не создаётся экземпляр класса работы с SQL и выскакивает ошибка. Пришлось из пустого конструктора добавить вызов конструктора с параметром с передачей ему нового класса для SQL. 
21 ФИНАЛЬНЫЙ УРОК. Презентация без видео
35 чел. ★ 4.9 Done
  Сделай видео-презентацию своей программы.
На видео необходимо ответить на следующие вопросы:
0. Показать, что у тебя получилось.
1. Чему ты научился на этом курсе?
2. Что тебе понравилось, что нет?
3. Что ты ещё добавишь в свой проект?
4. Какой следующий курс ты будешь проходить?
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 6 мин. [Показать отчёт]
Научился: * Научился делать простые страницы на ASP.NET с доступом к базе данных. * В уроке с отказом от статика не был проверен функционал добавления записей, в котором появляется ошибка если просто статический класс доступа к базе данных перевести в экземплярный. * В проект следует добавить возможность редактирования и удаления записей. * Пока думаю. 
Видеообзор: p3F2M5dM5HY
22 VIP. Авторизация на сайте 00:37:47
32 чел. ★ 4.9 Done
  На этом уроке мы создадим в базе данных таблицу users,
добавим туда одну запись и реализуем авторизацию администратора

Отчёт отправил: 10080. FireWolf Выполнено за 1 день 13 час. 27 мин. [Показать отчёт]
Научился: Научился делать простую проверку логина пользователя. Ошибку с добавлением новой записи после избавления от статика я как раз на прошлом уроке заметил и исправил :) 
23 VIP. Модерация записей 00:59:29
29 чел. ★ 4.9 Done
  На этом уроке мы реализуем функционал администратора сайта.
Администратор сможет подтверждать истории для публикации.
Отчёт отправил: 10080. FireWolf Выполнено за 1 день 10 час. 12 мин. [Показать отчёт]
Научился: Очень познавательно! Научился сохранять сессию при авторизации, делать проверку записей авторизованным пользователем, менять записи в колонке статуса истории в базе и выводить истории в зависимости от записи в колонке статуса истории. Так как в MSSQL не поддерживается enum в качестве типа записи, то реализовал через CONSTRAINT. 
24 VIP. Установка домена 00:15:27
24 чел. ★ 5 Open
  На этом уроке мы покажем, как просто можно
купить и привязать домен к вашему проекту.
  Итого:   24 видеоурока 8 час. 41 мин.
1 тест
24 чел. ★ 4.88  
  Финалисты:   Михаил Ермишин,   Nromik,   Елена,   Аркадий,   valerys Nikola,   Tekashnik,   Сергей,   zhikharevav,   Максим,   Сергей Соколов,   Ludmila,   Алексей Хонин,   Станислав,   Константин,   WildOrc,   Алексей|BrisK|Кривицкий,   alklokov,   Dmitry Sinitsin,   Владимир,   Max,   Александр,   Rita,   vip,   Evgenii Kudriavtcev .

Начинаем практику по языку C#





Если вы пришли без приглашения -
введите тысяча двадцать четыре (цифрами).
Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.


Научился: Подвел итоги и оценил свои достижения при изучении курса. Прикинул направление дальнейшего развития своего проекта.
Трудности: Обобщение, обзор темы с "высоты"
Понравилась практическая направленность курса. Из недостатков: малый объем, хотелось бы, чтобы курс охватывал ASP.NET MVC полнее. В моих планах добавить вывод графики в представлении, в идеале интерактивной


Научился: Даже не знаю - не мандражировать по поводу отзыва.
Трудности: Записать отзыв после праздников.
Не так страшен asp.net mvc как его малюют.