Error 404 run angular Asp.net core

Asked

Viewed 112 times

1

I am doing a project integrating the angular with Asp.net core, but as soon as I installed the angular and configured on the page this presenting error 404, even reviewing all the paths made by angular still presents the error when run. Note: if I take the angular page the page normally loads.

Index.html

<app-root></app-root>

<script src="~/ClienteApp/dist/polyfills.js"></script>
<script src="~/ClienteApp/dist/runtime.js"></script>
<script src="~/ClienteApp/dist/styles.js"></script>
<script src="~/ClienteApp/dist/vendor.js"></script>
<script src="~/ClienteApp/dist/main.js"></script>

app.componentts.

import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  template: `
    <!--The content below is only a placeholder and can be replaced.-->
    <div style="text-align:center">
      <h1>
        Welcome to {{title}}!
      </h1>
      <img width="300" src="">
    </div>
    <h2>Here are some links to help you start: </h2>
    <ul>
      <li>
        <h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
      </li>
      <li>
        <h2><a target="_blank" rel="noopener" href="https://angular.io/cli">CLI Documentation</a></h2>
      </li>
      <li>
        <h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
      </li>
    </ul>
    <router-outlet></router-outlet>
  `,
  styles: []
})
export class AppComponent {
  title = 'AngularApp';
}

Angular.json

  • Are you running on dotnet run or npm direct in the Clienteapp? I saw that you have the Views folder, you are using Razor also?

  • In the view folder is index.cshtml, I am running dotnet and updating the angular by ng build at the prompt.

  • Just to isolate the problem, if you run within the clienteapp direct by ng works?

  • I checked in the clienteApp folder, and I used ng serve and downloaded the generated localhost, then it appears normally. And when I run on dotnet still keeps giving error 404.

  • But somewhere in your Startup you need to indicate that it is to redirect to the Index.html page, otherwise Asp.net core won’t know. Since you didn’t post the startup I don’t know if it is 100% correct, but I will answer with a solution and you test!

1 answer

0


Please try adding the route to Index.html so that Asp.net core can pass control to the angular:

Use inside Configure (Startup):

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

            // Rewrite request to use app root
            if (context.Response.StatusCode == 404 && !Path.HasExtension(context.Request.Path.Value) && !context.Request.Path.Value.StartsWith("/api"))
            {
                context.Request.Path = "/index.html"; 
                context.Response.StatusCode = 200; // Make sure we update the status code, otherwise it returns 404
                await next();
            }
        });

Remember to use Static files and defaultroute, later to the above code:

       app.UseStaticFiles();
       app.UseMvcWithDefaultRoute();
  • My code was missing from "app.Usestaticfiles", which is why it wasn’t locating the file paths. Thank you :)

Browser other questions tagged

You are not signed in. Login or sign up in order to post.