Готовим ASP.NET5, выпуск №1 – поговорим про статический контент

Этой статьей я открываю авторскую колонку про технологии, секреты, советы и лучшие практики новой версии ASP.NET5. Платформа .NET стремительно движется к кроссплатформенности и ее веб-часть — ASP.NET — в том числе. Вы уже слышали и можете найти массу информации в сети и в том числе на Хабре о том, что .NET становится opensource, о выпуске новых версий и официальной поддержке .NET на OSX, Linux. Вместе с этими анонсами и ASP.NET5 становится доступным на большем числе платформ для большего круга разработчиков.

4c4d842ab4fd4d86b57440bad7ce3814.png


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

Тема первого выпуска — работа со статическими файлами в ASP.NET5 — задача насколько тривиальная, настолько же и важная.

aspnetcolumngithubСовет! Вы можете попробовать все самостоятельно или загрузив исходный код из GitHub https://github.com/vyunev/aspnetcolumn1.


Новый подход


В ASP.NET5 подход к работе со статическими файлами сильно изменился, сразу по нескольким направлениям. Начнем с того, что в проекте в Visual Studio и при работе с проектами в других редакторах для статического контента предлагается отдельная папка — wwwroot (Рис. 1). По сути, содержимое wwwroot теперь отображает файловое представление сайта на веб-сервере.

image
Рис. 1 — Структура проекта ASP.NET5 (beta5)

Использование отдельной папки для статического контента позволяет упростить многие задачи, включая работу с системами контроля версий, кэширования контента на CDN, задач минификации и упаковки файлов, конфигурирования обработки запросов веб-сервером.

Кроме того, введение wwwroot позволяет сделать работу сайта безопаснее, так как запросы к файлам на сайте теперь могут быть обращены только к содержимому wwwroot, а внешние конфигурационные или другие файлы, лежащие вне этой папки недоступны для запроса.

При желании, разработчики могут изменить имя этой папки с помощью параметра конфигурации webroot в project.json (Рис. 2).

image
Рис. 2 — Изменение имени папки для статического контента через файл конфигурации

Совет! Для переименования папки через Visual Studio, лучшие всего, первым шагом выполнить переименование в Solution Explorer и только потом изменить конфигурационный файл. Иначе, умная Visual Studio создаст новую папку самостоятельно.


Другой важный параметр конфигурации — это включение пакета Microsoft.AspNet.StaticFiles в список зависимостей проекта ASP.NET, этот пакет позволяет конвейеру платформы обрабатывать статический контент (Рис. 3).

image
Рис. 3 — Включение пакета в список зависимостей проекта ASP.NET

После включения пакета в список зависимостей требуется добавить обработку в конвейер обработки запросов ASP.NET. Подобная конфигурация выполняется в методе Configure специального служебного класса Startup, который по умолчанию располагается в файле Startup.cs (Рис. 4).

image
Рис. 4 — Включение обработки статических файлов

После указанной конфигурации весь статический контент, запрошенный у сайта будет отдаваться из определенной конфигурацией папки.

Расширение функционала


В ASP.NET5 каждую часть платформы можно переопределить, дополнить или заменить. Мы можем определить свой собственный обработчик статических файлов или дополнить существующий, указав новые правила. Например, если мы хотим добавить возможность возвращать *.json файлы как статические, нам достаточно определить следующий провайдер контента:

Листинг 1. — Определение провайдера типа контента
image

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

Листинг 2. — Использование провайдера типа контента
image

При определении работы конвейера обработки запросов для статических файлов можно указать еще несколько параметров. Для этого у StaticFileOptions есть набор свойств. Перечислю некоторые из них:

  • ServeUnknownFileTypes — позволяет указать конвейеру обрабатывать все неизвестные типы файлов при запросе, по умолчанию установлено значение false;
  • DefaultContentType — позволяет указать тип контента, который будет присваиваться по умолчанию запросом к неопределенным типам файлов. По умолчанию установлено в none.


На этом можно завершить введение в тему обработки статического контента на базе ASP.NET5.

Свежие новости


Выпущено обновление ASP.NET5 Beta5 с множеством изменений, улучшений и исправлений ошибок. Подробности обновления можно найти в этом блоге. Внимательно ознакомитесь со списком изменений, которые могут повлиять на предыдущий код при обновлении.

С выходом ASP.NET5 Beta5 обновился и набор инструментов ASP.NET 5 yeoman generators, который поддерживает кроссплатформенную разработку на ASP.NET и позволяет генерировать код (скаффолдинг) для проектов из командной строки в любой ОС. О самом проекте можно почитать тут.

Образ контейнера Docker с ASP.NET5 Beta5 опубликован на официальном Docker Hub.

Опубликованы доклады конференции DevCon 2015, в том числе по веб-разработке и теме ASP.NET.

Полезные ссылки


Самая свежая документация по ASP.NET5 расположена по адресу http://docs.asp.net/en/latest/.

Познакомьтесь с демонстрационным проектом PiDnx от Дэмиана Эдвардса, который показывает как запускать ASP.NET5 на Raspberry Pi 2 на базе Windows 10 IoT Core.

Изучите основы ASP.NET5 с новым бесплатным курсом виртуальной академии Microsoft.

Авторам


Друзья, если вам интересно поддержать колонку своим собственным материалом, то прошу написать мне на vyunev@microsoft.com для того чтобы обсудить все детали. Мы разыскиваем авторов, которые могут интересно рассказать про ASP.NET и другие темы.

Об авторе


Владимир Юнев
Эксперт по стратегическим технологиям, Microsoft, Россия8929390a6ac7473b8677f53a04a6c691.jpg

Владимир Юнев — сертифицированный разработчик приложений с более чем 12-летним стажем работы. Работает в департаменте стратегических технологий Майкрософт Россия, отвечая за темы использования облачных и веб-технологий Microsoft в веб-приложениях, сервисах и мобильных клиентах. Постоянный участник и организатор множества российских ИТ-конференций, автор книги по разработке веб-приложений на платформе ASP.NET MVC. В сообществе разработчиков известен под ником XaocCPS.

Буду рад пообщаться с вами: Twitter — https://twitter.com/XaocCPS и Facebook — https://www.facebook.com/yunev.

Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.

© Habrahabr.ru