Skip to content

utilitydelta/spa-angular2-dotnet-auth

Repository files navigation

Single Page Application with Angular2, ASP.NET 6 and Identity

The purpose of this repository is to document the steps involved in building a 'Single Page Application' using Angular2 and ASP.NET. This project uses the latest versions of Angular2 and ASP.NET 6.

See a live demo here: http://spa-angular2-dotnet-auth.azurewebsites.net


Backend

  • It is designed to be deployed to an IIS Server with Windows OS. It uses the full .NET framework.
  • The project uses ASP.NET Identity. The user 'store' has been setup not to use the default EntityFramework implementation however. This allows you to plugin your own method for authentication (eg. Active Directory, External System, etc.)
  • The backend API is secured by default. Users must login to access data.
  • Any POST/PUT/DELETE calls to the backend check the Anti-forgery token to prevent CSRF.

Frontend

  • The frontend has bootstrap 4 with ng-bootstrap (no JQuery). Bootstrap is brought in via the SCSS source to allow overriding of styles, customisation without forking the code.
  • Angular2 uses the Angular2 CLI. This avoids us having to use webpack directly, simplifying the development & build processes.
  • The frontend uses Angular2 routing, SASS for CSS preprocessor.
  • The build process moves the frontend code into the backend project for deployment to server.

Getting Started

  • Make sure you have .NET Core tooling installed, Visual Studio 2015 Update 3, VS Code, Node.JS, Angular CLI
  • Fork the code and clone down to your machine.
  • Open up UtilityDelta.Backend in VS and run it. Check that your browser opens http://localhost:54216/
  • Go to the terminal (Ctrl+~) and type 'npm install'. After the dependencies are installed, type 'npm start'.
  • Open up http://localhost:4200 and login

Debugging the Frontend From VS Code

Install the 'Debugger for Chrome' extension for VS Code. Add the following to the target for the shortcut to open the Chrome browser:

--remote-debugging-port=9222

Run 'npm start' to start the server. Open up Google Chrome, navigate to the site:

http://localhost:4200/

You can now hit F5 in VS code and it should hit your breakpoints in *.ts files.


Build for Production

  • You can test the process by running 'npm run build'
  • Results of the build go into the wwwroot in the ASP.NET project
  • You can then deploy the ASP.NET project
  • This process can also be used in a build server deployment process by using NodeJS on the build server and running the 'npm run build' command before building the .NET backend.