无法在 dotnet core api 上调用控制器方法:没有中间件来处理请求

Phi*_*ier 5 c# .net-core asp.net-core-webapi angular

我的 dotnet 核心 api 有角度问题。我只是制作了一个登录表单和一个 UserController 来使用 jwt 处理登录请求,但是每当我点击“登录”按钮并从我的 angular 应用程序调用 UserController 的登录方法时:

this.http.post<any>(environment.baseUrl + `api/user/login`, user)
Run Code Online (Sandbox Code Playgroud)

我总是收到以下消息:

“SPA 默认页面中间件无法返回默认页面 '/index.html',因为它没有找到,并且没有其他中间件处理该请求。”

我正在寻找的不仅仅是解决方案,因为我一整天都在寻找解决它的方法,但我不知道如何解决它。我查看了 iis 日志、事件查看器日志。我尝试调试并进行了大量的互联网研究,但我找不到实际处理此类错误的正确方法

由于错误是由 dotnet 核心框架引发的,我真的不知道如何确定是我的控制器坏了还是我在配置服务时犯了错误。

你通常如何解决这个问题?提前感谢您的时间和帮助;)

启动.cs:

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        var ConnectionString = Configuration.GetConnectionString("Default"); 
        services.AddDbContext<TheCompanyContext>(options => options.UseSqlServer(ConnectionString));

        services.AddControllers();
        services.AddSpaStaticFiles(configuration =>
        {
            configuration.RootPath = $"ClientApp/dist";
        });

        services.ConfigureCORS();

        var key = Encoding.ASCII.GetBytes(Configuration["AppSettings:AuthenticationSecret"]);
        services.AddAuthentication(x =>
        {
            x.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
            x.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
        })
        .AddJwtBearer(x =>
        {
            x.RequireHttpsMetadata = false;
            x.SaveToken = true;
            x.TokenValidationParameters = new TokenValidationParameters
            {
                ValidateIssuerSigningKey = true,
                IssuerSigningKey = new SymmetricSecurityKey(key),
                ValidateIssuer = false,
                ValidateAudience = false
            };
        });

        services.AddAuthorization(options =>
        {
            options.FallbackPolicy = new AuthorizationPolicyBuilder()
                .RequireAuthenticatedUser()
                .Build();
        });
    }

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/Error");
            app.UseHsts();
            app.UseHttpsRedirection();
        }

        app.UseStaticFiles();
        app.UseSpaStaticFiles();
        app.UseSpa(spa =>
        {
            spa.Options.SourcePath = "ClientApp";
        });

        app.UseRouting();

        app.UseAuthentication();
        app.UseAuthorization();

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
        });
    }
}
Run Code Online (Sandbox Code Playgroud)

用户控制器.cs:

[Route("api/[controller]/[action]")]
[ApiController]
public class UserController : Controller
{
    public UserController(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    [HttpPost]
    [AllowAnonymous]
    public ActionResult Login([FromBody]User user)
    {
        // do login stuff
    }
}
Run Code Online (Sandbox Code Playgroud)

Phi*_*ier 1

我从头开始重新启动一个项目并设法解决了该问题。我真的不知道是什么解决了这个问题,但这是我做的三件事:

  • 修改 CORS 政策
  • 重新设计 Angular 和 dotnet 的环境设置
  • 解决了数据库连接问题

我的猜测是我的环境设置有点糟糕,我请求了错误的 api url,CORS 阻止了我。所有这些都隐藏了我的数据库问题。

抱歉,我对此没有适当的解决方案,但由于我在这方面浪费了很多时间,因此重新启动更容易^^

不管怎么说,还是要谢谢你