Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/DanWahlin/AngularCLI-ASPNET-Core-CustomersService

Example of integrating Angular with ASP.NET Core RESTful Services
https://github.com/DanWahlin/AngularCLI-ASPNET-Core-CustomersService

angular asp-net-core entity-framework-core webapi

Last synced: 4 days ago
JSON representation

Example of integrating Angular with ASP.NET Core RESTful Services

Awesome Lists containing this project

README

        

# Angular ASP.NET Core Project

This project provides an example of getting started using
ASP.NET Core and Angular together in one project and is an updated version of the code shown in the [Integrating Angular with ASP.NET Core RESTful Services on Pluralsight](https://www.pluralsight.com/courses/angular-aspnetcore-restful-services). If you're coming from the Pluralsight course you'll find the Angular code for the project in the `Client` folder now.

The project has the following goals:

* Keep the Angular project code completely separate from the ASP.NET Core code to make updates of either technology easier in the future. This was a key consideration when organizing the folders/files in the project.

* Provide a way to serve an Angular application using an MVC view (you can easily change this to serve from a Razor Page as well).

* Allow standard MVC controllers/views to be used in situations where part of the application runs outside of Angular.

* Support running the Angular project completely separate from the ASP.NET Core Web API if desired (CORS is enabled in the Startup.cs project). See the notes below if you want to use this option.

## Running the Project

To run the project perform the following steps:

NOTE: If you're on Windows, download the project from Github as a .zip file, and want to open the project in Visual Studio, make sure you unblock the .zip file first. Right-click on it, select Properties, and check the Unblock checkbox.

1. Install Node.js 14 or higher - https://nodejs.org

2. Install ASP.NET core 5 or higher - https://dot.net

3. Install the Angular CLI:

`npm install -g @angular/cli`

4. Open a command prompt and `cd` into the project's `Client` folder

5. Run `npm install`

6. Run `ng build --watch` to start the Angular build process and watch for changes.

7. Open a new command window in the root of the project and run the following commands:

```
dotnet restore
dotnet build
dotnet watch run
```

8. Visit http://localhost:5000 in the browser

9. An MVC view is serving the Angular application.

NOTE: If you get a certificate error due to the HTTPS redirect, run the following command to install a local dev certificate:

`dotnet dev-certs https --trust`

## Running Angular Separately from ASP.NET Core

If you'd like to run the Angular project completely separate from ASP.NET Core perform the following steps:

1. Open a new command window in the root of the project and run the following commands to restore, build and run the ASP.NET core project:

```
dotnet restore
dotnet build
dotnet watch run
```

2. Open the `Client/src/environments/environment.ts` file and change the `apiUrl` property to `http://localhost:5000/api/`

3. Launch the Angular project by running `ng serve -o`

4. Note that to do an `ng build` you'll need to open the `Client/angular.json` file and change the `outputDirectory` property to a value of `dist`.

A few additional notes:

* CORS is enabled in the `Startup.cs` file. You'll more than likely want to lock-down some of the settings for it though.
* Cross-Site Request Forgery (XSRF) is turned on by default for the Web API POST/PUT/DELETE methods. You may want to remove the associated attribute from these methods since in a real-world scenario you'd likely implement token authentication
in the API when ASP.NET Core is running as a separate/reuseable service.