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

Формула программиста
основатель — Волосатов Евгений Витольдович

Базовый ASP.ект

Практическое знакомство с технологиями
ASP.NET + MVC + MySQL

Пройди вместе с нами весь путь создания рабочего
web-проекта от планирования до размещения на хостинге.

Для кого этот курс
+ для тех, кто давно хочет создать web-проект
+ для начинающих программистов
+ для веб-разработчиков

Преимущества курса
+ Поэтапная разработка проекта
+ Короткие видеоуроки
+ Практические задания
+ Минимум теории, максимум практики
+ Чёткий пошаговый алгоритм: повтори и получи

Авторы курса
Евгений Волосатов
Валерий Жданов

Мы целенаправленно упростили суть сайта,
для того чтобы в короткие уроки вложить
все этапы создания готового проекта,
но при этом не погрязнуть в мелочах,
мы оставили место для творчества :)

Краткое содержание курса
1. Схема проекта с адресами
2. Использование модели, вида и контроллера
3. Создание базы данных и её установка
4. Создание ядра проекта - моделей
5. Связь моделей с видом через контроллеры
6. Проверка POST-данных
7. Размещение проекта на своём хостинге

Объём: 16 мини уроков
Технологии: ASP.NET, MVC, MySQL, Bootstrap, JavaScript,

3,000 руб.


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

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

# Название видеоурока Решило Рейтинг Доступ
1 Мы начинаем ASP.NET с MVC 00:06:08 72 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: Создавать проект на ASP.NET 
Сложности: просто  
Комментарии: Супер пора осваивать веб технологии 
2 Выбор темы для проекта 00:02:35 60 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: Создавать схему будущего сайта  
Сложности: Придумать свои проекты.  
Комментарии: 1. Сайт аналог WinForm - База данных восхождений для тур клуба. 2. Сайт визитка. 
3 Создание схемы проекта 00:06:41 55 чел. ★ 4.7 Done
  Отчёт отправил: 5219. Nromik Решено за 15 мин. [Показать отчёт]
Научился: Создавать схему проекта  
Сложности: Просто 
Комментарии: Тестовая история. Текст тестовой истории ))) 
4 Создание пустых страниц 00:10:50 50 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 40 мин. [Показать отчёт]
Научился: Начал осваивать ASP.NET 
Сложности: null 
Комментарии: cool 
5 Создание модели Story 00:00:00 34 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 30 мин. [Показать отчёт]
Научился: Создание модели Story 
Сложности: просто 
Комментарии: Круто  
6 Формирование меню 00:10:46 33 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 00 мин. [Показать отчёт]
Научился: Использовать @Html.ActionLink.  
Сложности: Просто 
Комментарии: Возник вопрос когда дебажу. Ставлю остановку на строчке Story story = new Story(); и запускаю проект. Происходит остановка, я нажимаю F11 (Step Into) и захожу в конструктор Story() и инициализирую переменные, выхожу с него. дальше строчка return View("Number", story); должен зайти в файл _ViewStart.cshtml. но сразу дохоже до конца метода и все. Почему на видео был заход в файл _ViewStart.cshtml. и дальше в _Layout.cshtml. Происходит заход в том случае если у меня в файл _ViewStart.cshtml. стоит остановка.  
7 Установка сервера MySQL 00:08:39 32 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: устанавливать MySQL 
Сложности: Просто 
Комментарии: Обычно хостинг для ASP.NET идет с MS SQL. а PHP c MySQL. Может лучше использовать MS SQL 
8 Схема базы данных 00:15:58 32 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: Ознакомился с программой HeidiSQL. 
Сложности: просто 
Комментарии: нету 
9 Создание SQL-запросов 00:20:44 31 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: писать не правильные запросы к базе данных.  
Сложности: ничего  
Комментарии: простые запросы  
10 Подключение к базе данных 00:25:51 28 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 00 мин. [Показать отчёт]
Научился: подключатся с проекта к базе данных  
Сложности: просто 
Комментарии: норм 
11 Работа над ошибками 00:36:57 26 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 30 мин. [Показать отчёт]
Научился: Обрабатывать ощыбки 
Сложности: Просто  
Комментарии: Конечно это не обрабатывает потерю соединения с базой дынных  
12 Запуск модели Story 00:35:22 23 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 20 мин. [Показать отчёт]
Научился: Принимать параметр id в адресной строке.  
Сложности: Просто 
Комментарии: Норма. 
13 Что такое SQL-инъекция 00:25:24 22 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 40 мин. [Показать отчёт]
Научился: Защищаться от SQL инекции 
Сложности: Норм 
Комментарии: Начальная защита или решает 95 % всех проблем. 
14 Рефакторинг модели Story 00:05:28 22 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 20 мин. [Показать отчёт]
Научился: Рефакторить  
Сложности: Подобрать имена методам. 
Комментарии: Немного по другому отрефакторил. 
15 Работа со списком историй 00:24:25 22 чел. ★ 5 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 15 мин. [Показать отчёт]
Научился: Добавлять модель в представление. Выводить список историй. 
Сложности: просто 
Комментарии: Круто 
16 Добавление истории 00:43:20 21 чел. ★ 5 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 00 мин. [Показать отчёт]
Научился: Добавлять истории 
Сложности: просто 
Комментарии: Переписал обработку ошибок классическим способом как рекомендуют в С# с помощью Исключений. Изменил подключение к базе. создал отдельный класс ErrorControler b Присоединяю архив для ознакомления Основы обработки исключений - http://professorweb.ru/my/csharp/charp_theory/level8/8_1.php 
17 Валидация данных 00:23:09 21 чел. ★ 5 Done
  Отчёт отправил: 5219. Nromik Решено за 30 мин. [Показать отчёт]
Научился: Проверять поля на пустые значения и писать регулярные выражения. 
Сложности: просто 
Комментарии: Это все круто. а не лучше организовать проверку на стороне клиента и лишне не грузить сервер. Как сделано на сайте videosharp.info 
18 Оформление сайта 00:46:07 20 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 2 час. 00 мин. [Показать отчёт]
Научился: Оформлять проект 
Сложности: много всего  
Комментарии: Норм дизайн 
19 Размещение проекта в Интернете 00:33:42 18 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 2 час. 00 мин. [Показать отчёт]
Научился: Размещение проекта в Интернете http://nromik-001-site1.ctempurl.com/ 
Сложности: всего по немногу 
Комментарии: в папке bin/*.dll - нужны. 
20 Отказ от статика 00:13:42 18 чел. ★ 4.7 Done
  Отчёт отправил: 5219. Nromik Решено за 15 мин. [Показать отчёт]
Научился: Бороться с ошибками. 
Сложности: норм. 
Комментарии: Я эту ошибку нашел уже давно в уроке 11.-Работа над ошибками. Я теснил и заметил что после того как было разорвано соединение с сервером он обратно не восстанавливал связь. Было принято решение переписать класс MySql. Идея статического класса очень крутая так как мы инициилизируем переменную MySqlConnection connection один рез и не лазим каждый раз в конфиг (экономим время). Подключение я осуществляю в блоке using (connection) (пример метод select) в котором я подключаюсь (если подключение созданное и лежит в пуле то я беру его от туда) и при выходе с блока using подключение закрывается ( ложится в пул). Тем самым я экономлю время на подключение к базе данных. остался один вопрос как такой метод поведет себя при больших нагрузках?? Метод AddSlashes нужно доработать. http://php.net/manual/ru/function.addslashes.php public static class SomeSql { private static MySqlConnection connection; static SomeSql() { InitializationConnectionToDataBase(); } private static void InitializationConnectionToDataBase() { MySqlConnectionStringBuilder csb = new MySqlConnectionStringBuilder( WebConfigurationManager.ConnectionStrings["connection"].ConnectionString); csb.Pooling = true; connection = new MySqlConnection(csb.ConnectionString); } public static DataTable Select(string myQuery) { using (connection) { try { connection.Open(); DataTable table = new DataTable(); MySqlCommand cmd = new MySqlCommand(myQuery, connection); MySqlDataReader reader = cmd.ExecuteReader(); table.Load(reader); return table; } catch (MySqlException exInner) { var ex = new SomeSqlException(exInner.Message,exInner) { Query = myQuery }; throw ex; } } } static public string AddSlashes(string text) { try { return text.Replace("'", "\\'").Replace("\"", "\\\"").Replace("\\", "\\\\"); } catch (NullReferenceException) { return ""; } } } } 
21 ФИНАЛЬНЫЙ УРОК. Презентация 15 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 2 час. 00 мин. [Показать отчёт]
Научился: Делать презентацию. 
Сложности: спросто 
Комментарии: Круто  
Видеообзор: https://www.youtube.com/watch?v=COGjCw4y7fE
22 VIP. Авторизация на сайте 00:37:47 15 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 1 час. 10 мин. [Показать отчёт]
Научился: Все что знал повторил.  
Сложности: Просто 
Комментарии: Может надо логинить каждого пользователя, а потом добавлять истории. 
23 VIP. Модерация записей 00:59:29 13 чел. ★ 4.8 Done
  Отчёт отправил: 5219. Nromik Решено за 2 час. 15 мин. [Показать отчёт]
Научился: Проводить модерацию записей 
Сложности: норм. 
Комментарии: После того как я разместил сайт на хостинге и опубликовал решение на сайте через некоторое время у меня перестал отображаться главная страничка стал отрабатывать какой то ексепшен, а все остальное работало. Все вперлось в то что я исчерпал квоту для базы данных, тогда упростил запрос на главной странице - выкинув с него ORDER BY и все заработало . Потому хочу возразить свои возмущения по поводу запроса который мы написали на уроке: "SELECT id, title, story, email, post_date FROM story WHERE status = 'wait' ORDER BY post_date ASC LIMIT 1; - Ну зачем у нас ORDER BY по post_date это надо вытянуть все записи у которых status = 'wait', а потом произвести сортировку. Если у нас есть кластерный индекс по id который увеличивается со временем. P.S. Теперь понятно почему сайт http://www.videosharp.info/ иногда повисает))) 
24 VIP. Установка домена 00:15:27 11 чел. ★ 4.9 Done
  Отчёт отправил: 5219. Nromik Решено за 30 мин. [Показать отчёт]
Научился: Устанавливать домен 
Сложности: Норм 
Комментарии: * нету надобности регистрировать домен. 
  Итого:   24 видеоурока общей продолжительностью 8 час. 28 мин. 11 чел. ★ 4.86  
  Финалисты:   Михаил Ермишин,   Nromik,   Елена,   Аркадий,   valerys Nikola,   Tekashnik,   Сергей,   zhikharevav,   Максим,   Сергей Соколов,   Ludmila .

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




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

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

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

Ты в любой момент сможешь отписаться от рассылки.
Научился: Создавать ASP.NET MVC проекты, работать с базами данных, выполнять SQL запросы.
Трудности: ничего
Уроки отличные, спасибо авторам: Евгению Витольдовичу и Валерию Жданову
Смотреть видеозапись: https://youtu.be/BVYzj0ewyYc
Научился: Я научился создавать свои ASP.NET MVC приложения, вспомнил как работать с базами данных и научился работать с MVC моделями.
Трудности: Ничего
Данный курс был одним из самых полезных для меня. Я научился создавать свои сайты на C#. Спасибо, Евгений Витольдович, что создали этот прекрасный курс! P.S Но хостинг просто #вырвирукиразрабам xD :~/
Смотреть видеозапись: https://youtu.be/Y4LZ0AIYqL8