Как настроить ASP. NET Core 3.1 приложение для одновременного запуска ReactJS и MVC веб-сайта - PullRequest
0 голосов
/ 04 февраля 2020

У меня есть ASP. NET основной сайт реакции, созданный с помощью CRA . Приложение реагирования предназначено только для чтения и публикации c страниц.

Я также хочу, чтобы некоторые страницы администратора создавались как леса Razor Pages, например, ядра EF;

  • https://localhost/robots - реагировать на приложение, чтобы отобразить список роботов для пользователя
  • https://localhost/robots/admin - MVC приложение для отображения списка роботов и действий администратора для пользователя

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

Начальная конфигурация выглядит следующим образом;

        public void ConfigureServices(IServiceCollection services)
        {

            services.AddControllersWithViews();

            // In production, the React files will be served from this directory
            services.AddSpaStaticFiles(configuration =>
            {
                configuration.RootPath = "ClientApp/build";
            });

            services.AddDbContext<MyDbContext>(options =>
                    options.UseSqlServer(Configuration.GetConnectionString("MyDbContext")));
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            else
            {
                app.UseExceptionHandler("/Error");
                // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
                app.UseHsts();
            }

            app.UseHttpsRedirection();
            app.UseStaticFiles();
            app.UseSpaStaticFiles();

            app.UseRouting();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllerRoute(
                    name: "admin",
                    pattern: "admin/{controller}/{action=Index}/{id?}");
            });

            app.UseSpa(spa =>
            {
                spa.Options.SourcePath = "ClientApp";

                if (env.IsDevelopment())
                {
                    //spa.UseReactDevelopmentServer(npmScript: "start");
                    spa.UseProxyToSpaDevelopmentServer("http://localhost:3000");
                }
            });
        }

1 Ответ

0 голосов
/ 04 февраля 2020

В startup.cs отображение конечной точки сконфигурировано для MVC. Это можно заставить работать, но это будет легче изменить;

Изменить

app.UseEndpoints(endpoints =>
{
    endpoints.MapControllerRoute(
    name: "admin",
    pattern: "admin/{controller}/{action=Index}/{id?}");
});

на

app.UseEndpoints(endpoints =>
{
    endpoints.MapRazorPages();
});

Информация, полученная от https://andrewlock.net/comparing-startup-between-the-asp-net-core-3-templates/ и https://www.learnrazorpages.com/razor-pages/routing

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...