Перейти к содержанию

Создание приложения с использованием ASP.NET Core MVC и EF Core

1 Звезда2 Звезды3 Звезды4 Звезды5 Звезд (1 оценок, среднее: 5,00 из 5)
Загрузка...

[ Полезный рекламный блок ]

Попробуйте свои силы в игре, где ваши навыки программирования на C# станут решающим фактором. Переходите по ссылке 🔰.


В этой статьей рассмотрим процесс построения реалистичного проекта, который продемонстрирует совместное использование ASP.NET Core MVC и Entity Framework Core. Проект будет простым, но близким к реальности, и фокусироваться на часто применяемых средствах Entity Framework Core.  

Приложение будет управлять базой данных TV Shows, а его главная страница в конце будет выглядеть, как показано ниже. 

фильмы asp.net core

В этом проекте, я покажу альтернативные способы создания контроллеров на основе «scaffolding tools». 

Создание приложения с использованием ASP.NET Core MVC и EF Core

 

Создание и настройка проекта

Чтобы создать проект TvShows, запустите Visual Studio и выберите в меню File (Файл) — New Project (Создать Проект). Укажите шаблон проекта ASP.NET Core Web Application (Веб-приложение ASP.NET Core). Введите TvShows, в поле Name, на следующей странице укажите Framework .Net 7.0 и нажмите кнопку Create:

как создать проект asp.net core mvc

На данный момент у нас есть начальный проект. Давайте запустим проект (Crtl + F5), чтобы убедиться, что все в порядке. Ниже вы можете изменить браузер, с помощью которого вы хотите запустить сайт:

visual studio выбор бразуера

После запуска мы получаем страницу приветствия, как показано ниже:

стартовая страница asp net mvc

MVC вызывает классы контроллеров (и методы действий в них) в зависимости от входящего URL. Логика маршрутизации URL, используемая MVC по умолчанию, использует такой формат, чтобы определить, какой код следует вызвать:

Формат маршрутизации задается в файле Program.cs:

Когда вы переходите к приложению и не указываете никаких сегментов URL, оно по умолчанию использует контроллер HomeController и метод Index, указанный выше. Таким образом, если вы введете https://localhost:XXXX/Home/Index в качестве URL, вы получите ту же страницу приветствия, которая показана выше.

Модель и Репозиторий

Модель для приложения TVShows будет основана на списке фильмов. Для этого реализуем класс TvShow. Мы будем использовать этот класс с Entity Framework Core (EF Core) для работы с базой данных. EF Core — это фреймворк объектно-реляционного отображения (ORM), который упрощает код доступа к данным. Классы моделей не имеют зависимости от EF Core. Они просто определяют свойства данных, которые будут храниться в базе данных.

Создайте папку Models и добавьте в нее файл класса по имени TvShow.cs со следующим содержимым:

Затем добавьте еще один класс под названием Genre.cs, как показано ниже:

Далее создадим контроллер и представления (часть View-Controller приложения MVC). По умолчанию в нашем проекте, уже есть контроллер – HomeController.cs, удалим его и добавим снова.

Щелкните правой кнопкой мыши папку Controllers и выберите Add -> Controller. В следующем окне выберите «MVC Controller with views, using Entity Framework» и нажмите Add:

создание контроллера с scaffolding

В следующем окне выберите TvShow в качестве класса «Model» и нажмите знак + в классе «Data context» и дайте ему имя ApplicationContext. Оставьте значения по умолчанию для остальных полей и выберите — Добавить:

scaffolding mvc core

Если в ходе добавления возникла ошибка, со следующим содержимым:

«install the package microsoft.visualstudio.web.codegeneration.design and try again»

install the package microsoft.visualstudio.web.codegeneration.design

Перейдите в DependenciesManage NuGet PackagesBrowse и укажите в поиске:

Установите данную библиотеку. ВАЖНО! Если библиотека уже установлена и ошибка по-прежнему возникает, попробуйте пересобрать проект или же переустановить данную библиотеку вручную.

На этом этапе работает инструмент scaffolding. Автоматическое создание контекста базы данных и методов и представлений CRUD (create, read, update, and delete) действий известно как scaffolding.

Рассмотрим, что Visual Studio добавила в наш проект автоматически в результате использования строительных лесов.

Следующие методы являются методами действия контроллера TvShowsController:

  • Index (GET) 
  • Details (GET) 
  • Create (GET & POST) 
  • Edit (GET & POST) 
  • Delete (GET & POST)

scaffolding controller in mvc

Файлы представления Razor для страниц: Создать, Удалить, Подробности, Редактировать и Индекс, так же были созданы по адресу – Views / TvShows.

Автоматически были скачаны библиотеки необходимые для работы с Entity Framework Core:

ef core libraries

В корне проекта можно увидеть новую папку Data, со сгенерированным классом ApplicationContext:

ApplicationContext координирует функциональность EF Core (Create, Read, Update, Delete и т.д.) для модели TvShow. TvShowsContext является производным от Microsoft.EntityFrameworkCore.DbContext. Контекст данных определяет, какие сущности включены в модель данных.

Имя строки подключения передается в контекст путем вызова метода на объекте DbContextOptions. Для локальной разработки система конфигурации ASP.NET Core считывает строку подключения из файла appsettings.json, который уже успешно сгенерирован с необходимым содержимым, перейдем в файл и измени название базы данных на TvShowsDb:

ASP.NET Core построен с использованием инъекции зависимостей (DI). Службы (например, контекст БД EF Core) регистрируются с помощью DI во время запуска приложения. Компоненты, которым требуются эти службы, получают их через параметры конструктора:

В контроллере Controllers / TvShowsController.cs конструктор использует внедрение зависимостей для внедрения контекста базы данных (TvShowsContext) в контроллер:

Создание базы данных

Создадим базу данных с помощью функции EF Core Migrations. Миграции позволяет нам создать базу данных, соответствующую нашей модели данных, и обновлять схему базы данных при изменении модели данных.

Откройте Tools -> NuGet Package Manager > Package Manager Console (PMC) и выполните следующую команду в PMC:

Add-Migration Initial

Команда Add-Migration генерирует код для создания начальной схемы базы данных, которая основана на модели, указанной в классе TvShowsContext. Аргумент Initial — это имя миграции, можно использовать любое имя.

После выполнения команды в папке Migrations будет создан файл миграции:

файл миграции

В качестве следующего шага выполните следующую команду в Package Manager Console:

Команда Update-Database запускает метод Up в файле Migrations/{time-stamp}_InitialCreate.cs, который создает базу данных.

Теперь проверим созданную базу данных. Откройте View -> Sql Server Object Explorer. Вы увидите только что созданную базу данных по следующему пути:

миграции ef core

Как вы видите, таблица TvShows и таблица истории миграций создаются автоматически. Затем в таблицу истории миграций вставляется запись, чтобы показать выполненные миграции в базе данных.

Создание первой записи

Так как начальный контроллер HomeController был удален, а вместо него был создан новый – TvShowsController. Необходимо немного подправить систему маршрутизации, для этого перейдем в файл Program.cs и изменим начальный маршрут:

Запустите приложение, на главной странице нажмите по ссылке — Create New.

На данный момент выпадающий список Genre пуст. Мы отредактируем Create.cshtml, чтобы загрузить список из перечисления Genre, как показано ниже:

После сохранения Create.cshtml, если обновить браузер, изменения будут отражены, а выпадающий список жанра загружен. Теперь мы можем создать первую запись. (Аналогичные изменения следует сделать и в Edit.cshtml):

asp net core create

После нажатия кнопки Create, новая запись отображается на странице Index, как показано ниже:

asp net core mvc crud

Теперь мы будем показывать ImdbUrl как ссылку. Измените Views / TvShows / Index.cshtml следующим образом:

Добавление аннотаций в модель

В этом разделе добавим аннотации данных в нашу модель для целей проверки и отображения. Аннотации данных предоставляют встроенный набор атрибутов проверки, которые вы можете декларативно применить к любому классу или свойству. Он также содержит атрибуты форматирования, которые помогают в форматировании.

Изменим класс TvShow.cs, следующим образом:

Если запустим приложение и попытаемся создать новую запись, как показано ниже, мы сможем увидеть эффект от этих аннотаций данных:

asp.net core annotation validation

Ошибки внедряются как на стороне клиента (с помощью JavaScript и jQuery), так и на стороне сервера (в случае, если у пользователя отключен JavaScript).

Добавление нового свойства в модель

Теперь мы добавим свойство ImageUrl в наше приложение и покажем в записях постер телешоу. Реализовывать загрузку изображения на сервер в этом примере не станем, ограничимся обычной ссылкой. Процесс загрузку изображения на сервер, рассмотрим в последующих уроках.

Во-первых, добавим это свойство в модель TvShow:

Далее мы будем использовать Code First Migrations для добавления этого поля в таблицу db. Откройте Tools -> NuGet Package Manager > Package Manager Console (PMC) и выполните следующую команду в PMC:

После, команду:

Теперь обновим атрибут [Bind] для методов Create и Edit POST в контроллере TvShowsController.cs:

Далее нам необходимо изменить представления Index, Create, Edit, чтобы отобразить это новое поле.

Добавьте в файл Edit.cshtml и Create.cshtml следующую часть кода:

Так же, изменим файл Index.cshtml следующим образом:

В верхней части файла Index.cstml, добавим стилей для корректного отображения постеров фильмов:

Запустите приложение и выполните редактирование текущей записи, добавив к ней ссылку на изображение, попробуйте добавить новую запись. После, перейдите на главную страницу и посмотрите результат:

asp.net cire movie site

Добавление компонента статистики

Напоследок, добавим View Component, для отображения статистики по фильмам. В корне проекта создадим папку Components и добавим в нее новый класс StatisticsViewComponent.cs, со следующим содержимым:

В методе InvokeAsync(), считаем общее количество фильмов, а так же сгруппировав их по жанрам. В качестве модели, передаем в частичное представление Default.cshtml, которое мы создадим чуть позже.

В корне проекта, создадим папку ViewModels, в ней определим класс StatisticsViewModel.cs, со следующим содержимым:

Теперь создадим представление, которое будет выводить переданные из компонента данные. Добавим в папку Views / Shared новый каталог, который назовем Components. А в этот каталог добавим папку, которая называется по имени нашего компонента — Statistics, и определим в ней новое представление Default.cshtml со следующим содержимым:

На странице Index.cshtml, вызовем компонент с помощью тег-хелпера vc:

Однако перед использованием тега необходимо зарегистрировать наш компонент в качестве tag-хелпера. Для этого в файл _ViewImports.cshtml в папке Views добавим следующую директиву: 

Название сборки проекта, как правило, совпадает с названием самого проекта.

Запустим приложение и посмотрим на результат:

фильмы asp.net core

По такому принципу вы можете создавать собственные компоненты для ваших веб-сайтов.

На этом разработка проекта с использованием технологий ASP.NET Core MVC и EF Core подошла к концу.

Вы можете скачать исходный код в моем репозитории — Github.

Я надеюсь, что вам понравилось читать эту статью, и она оказалась легкой для понимания. Пожалуйста, дайте мне знать, если у вас есть какие-либо комментарии или исправления.

Так же вам может быть интересна предыдущая статья — Генерация robots.txt в Asp.Net.


Вы хотите научится писать код на языке программирования C#?

Создавать различные информационные системы, состоящие из сайтов, мобильных клиентов, десктопных приложений, телеграмм-ботов и т.д.

Переходите к нам на страницу Dijix и ознакомьтесь с условиями обучения, мы специализируемся только на индивидуальных занятиях, как для начинающих, так и для более продвинутых программистов. Вы можете взять как одно занятие для проработки интересующего Вас вопроса, так и несколько, для более плотной работы. Благодаря личному кабинету, каждый студент повысит качество своего обучения, в вашем распоряжении:

  • Доступ к пройденному материалу
  • Тематические статьи
  • Библиотека книг
  • Онлайн тестирование
  • Общение в закрытых группах

https://dijix.com.ua

Живи в своем мире, программируй в нашем.


 

 

Опубликовано в рубрикеAsp.Net Core
Подписаться
Уведомить о
guest
2 комментариев
Старые
Новые Популярные
Межтекстовые Отзывы
Посмотреть все комментарии
Darkmans
Darkmans
1 год назад

Спасибо за крутую информацию, сложно сейчас найти годные step-by-step статьи с обьяснением. Огромная благодарность!

Max Lernov
Max Lernov
1 год назад

Просто и гениально одновременно. Теперь я понимаю в целом структуру подобного рода проектов. Спасибо!!!

2
0
Оставьте комментарий! Напишите, что думаете по поводу статьи.x