Aspnet7+docker+React中的SPA重定向错误
创始人
2024-09-20 06:30:29
0
  1. 首先,在Dockerfile中,确保你已经使用的是ASP.NET Core SDK映像(例如:mcr.microsoft.com/dotnet/core/sdk:3.1)而非ASP.NET Core运行时映像。在这种情况下,你需要在Dockerfile中添加以下行来构建React应用程序并将生成文件复制到ASP.NET Core应用程序中:
FROM node AS build
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
RUN npm run build

FROM mcr.microsoft.com/dotnet/core/sdk:3.1
WORKDIR /app
COPY --from=build /app/build ./

ENTRYPOINT ["dotnet", "MyApp.dll"]
  1. 其次,在React应用程序(src/index.js)中使用BrowserRouter而不是HashRouter,并将basename属性设置为应用程序根目录路径:
import React from 'react'
import ReactDOM from 'react-dom'
import { BrowserRouter } from 'react-router-dom'
import App from './App'

const baseUrl = document.getElementsByTagName('base')[0].getAttribute('href')
const rootElement = document.getElementById('root')

ReactDOM.render(
  
    
  ,
  rootElement
)
  1. 最后,在ASP.NET Core中确保使用UseMvcWithDefaultRoute(而不是UseMvc)和MapFallbackToFile:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
    }
    else
    {
        app.UseHttpsRedirection();
        app.UseHsts();
    }

    app.UseStaticFiles();
    app.UseRouting();
    app.UseEndpoints(endpoints =>
    {
        endpoints.MapControllers();
    });

    app.Use(async (context, next) =>
    {
        await next();

        if (context.Response.StatusCode == 404 && !Path.HasExtension(context.Request.Path.Value))
        {
            context.Request.Path = "/index.html";
            await next();
        }
    });

    app.UseMvcWithDefaultRoute();
    app.UseSpa(spa =>
    {

相关内容

热门资讯

wepoker软件辅助程序!w... wepoker软件辅助程序!wpk软件是真的吗(透视)攻略-切实详细是真的挂暗藏猫腻,小编详细说明w...
wepoker有插件吗!wep... wepoker有插件吗!wepoker私人局开挂视频(透视)技巧-原来揭幕存在有挂1、实时wepok...
hhpoker辅助靠谱吗!we... hhpoker辅助靠谱吗!wepoker轻量版有透视吗(透视)脚本-竟然有挂真的是有挂1)wepok...
pokemmo脚本手机版!约局... pokemmo脚本手机版!约局吧开挂(透视)器-真是曝光是真的挂pokemmo脚本手机版破解侠是真的...
wpk德州局怎么透视!wepo... wpk德州局怎么透视!wepoker透视有没有(透视)技巧-果然普及是真的挂暗藏猫腻,小编详细说明w...
wepoker怎么看底牌!hh... wepoker怎么看底牌!hhpoker脚本(透视)app-切实总结是真的挂1、下载好wepoker...
竞技联盟破解版最新版!约局吧德... 竞技联盟破解版最新版!约局吧德州可以透视吗(透视)教程-都是详细真的是有挂1、下载好约局吧德州可以透...
wpk辅助插件!hhpoker... wpk辅助插件!hhpoker破解工具(透视)软件-一贯解谜真的是有挂1、hhpoker破解工具透视...
德州机器人代打脚本!德州局透视... 德州机器人代打脚本!德州局透视脚本(透视)技巧-都是分享是有挂1、不需要AI权限,帮助你快速的进行德...
佛手在线是不是有挂!拱趴大菠萝... 佛手在线是不是有挂!拱趴大菠萝怎么开挂(透视)攻略-原来必备存在有挂1、完成佛手在线是不是有挂有辅助...