Подключение проекта ASP.NET MVC к проекту ASP.NET WebForms

в 15:29, , рубрики: .net, ASP, ASP.NET, asp.net mvc 4, asp.net webforms, razor, метки: , , , ,

Зачем это может понадобится? Допустим у нас есть большое приложение ASP.NET WebForms и есть проект написанный на ASP.NET MVC и мы хотим их объеденить.

Допустим адрес нашего сайта такой: www.my-awesome-site.com и мы хотим чтобы MVC был доступен по адресу www.my-awesome-site.com/mvc-stuff

Предусловия: у нас есть решение с двумя проектами — ASP.NET Web Application (WebFormsApplication) и ASP.NET MVC проект (MvcApplication).

Что нужно сделать.
1. Установить ASP.NET MVC для WebFormsApplication
2. Добавить ссылку в WebFormsApplication на MvcApplication
3. Добавить публичный метод в MvcApplication аналогичный Application_Start
4. Вызвать этот метод в Application_Start приложения WebFormsApplication
5. С помощью Razor Generator включить Views в сборку MvcApplication
4.…
5. Profit!!!

1. Установим ASP.NET MVC для WebFormsApplication, делается через nuget следующей командой: Get-Project WebFormsApplication | Install-Package AspNetMvc

2. Добавим ссылку в WebFormsApplication на MvcApplication. Тут все просто — Add Reference… дальше вы знаете

3. Добавим публичный метод в MvcApplication аналогичный Application_Start
Код Global.asax MvcApplication

public class MvcApplication : System.Web.HttpApplication
    {
        protected void Application_Start()
        {
            Start();
        }

        public static void Start(string prefix = null)
        {
            AreaRegistration.RegisterAllAreas();

            WebApiConfig.Register(GlobalConfiguration.Configuration);
            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
            // let's register routs with prefix
            RouteConfig.RegisterRoutes(RouteTable.Routes, prefix);
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            AuthConfig.RegisterAuth();
        }
    }

Сдесь есть такой параметр как “prefix”, он нужен для роутинга. Соответственно изменим метод RegisterRoutes класса RouteConfig, чтобы он мог принимать этот параметр.

Код RouteConfig MvcApplication

public class RouteConfig
    {
        public static void RegisterRoutes(RouteCollection routes, string prefix)
        {
            if (!string.IsNullOrEmpty(prefix) || !prefix.EndsWith("/"))
            {
                prefix += "/";
            }

            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                name: "Default",
                url: prefix + "{controller}/{action}/{id}",
                defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
            );
        }
    }

4. Добавим вызов этого метода в Application_Start приложения WebFormsApplication
Код Application_Start Global.asax WebFormsApplication

void Application_Start(object sender, EventArgs e)
        {
            // Code that runs on application startup
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            AuthConfig.RegisterOpenAuth();

            // Here we add MVC app
            MvcApplication.MvcApplication.Start("mvc-stuff");
        }

5. С помощью Razor Generator включим View в сборку MvcApplication
Для этого нужно установить Razor Generator через Extensions and Updates (не путать его с Razor Single File Generator for MVC)
6. Установим Razor Generator для проекта MvcApplication, делается это через nuget следующей командой Get-Project MvcApplication | Install-Package RazorGenerator.Mvc

Теперь для нужных View задать свойства Build Action: None, Custom Tool: RazorGenerator. После чего для View сгенерятся файлы с именем viewName.generated.cs

На этом все. Теперь можно сбилдить проекты и посмотреть что получилось.

Вот несколько ссылок по теме
Razor Generator
Precompile your MVC Razor views using RazorGenerator
ASP.NET MVC — как использовать вместе с WebForms
ASP.NET MVC — как вынести часть приложения в отдельную сборку?
ASP.NET WebForms and ASP.NET MVC in Harmony

Автор: sentyaev

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js