data:image/s3,"s3://crabby-images/a9754/a9754d109617d94c7b5b30bdfca53940234e3123" alt=""
Getting the .Net Core Web API and the Angular CLI to work together can be a daunting task. Here is a step by step guide.
Being a Microsoft fan-boy in the early 2000s was not advantageous nor fun. During the dark days of Com+, Dcom and “classic” asp I seriously considered going to law school. Everything was closed to extension and nearly impossible to modify or integrate.
Today Angular 4, a framework written by Google, was written using Microsoft’s TypeScript (Microsoft being our protagonist and principal enemy of Google). Let that roll around in your noodle for a bit. Now add the fact that Microsoft’s flagship development platform seems to be going opensource on top of embracing 3rd party packages and frameworks.
“Dogs and cats living together” ~ Dr. Peter Venkman
With that said why the hell is ASP.NET Core Web API so damn annoying to work side by side with AngularJS 2 errrrr ahhhh I mean AngularJS 4 CLI?
Why in the hell won’t my Mother Trucking TypeScript transpile? ~Said every Angular Developer Using Visual Studio Ever…
I will try to distill this down to a few steps. By the way I am using Visual Studio 2017
Before we Begin
Is Angular 4 CLI installed? npm install -g @angular/cli
- Open PowerShell or a basic command line.
- Create a folder for your project.
md testProj
data:image/s3,"s3://crabby-images/9f59a/9f59a1766a06d3eecbb182ae6e211961015167ac" alt=""
Step 1: Create a new WebApi project from the command line. dotnet new webapi
Step 2: Open the .csproj file in notepad. notepad.exe testProj.webapi'
Step 3: Add the below TypeScriptCompilerBlocked to the PropertyGroup section and save. This will let the Angular CLI compile your typescript and not Visual Studio.<TypeScriptCompilerBlocked>true</TypeScriptCompilerBlocked> <PostBuildEvent>ng build --aot</PostBuildEvent>
data:image/s3,"s3://crabby-images/02a46/02a464148e92659a1d9da521b5e512facccbf5fb" alt=""
Step 4: Open the webAPi project via the environment or open it from the CLI. devenv testproj.csproj
Step 5: Open the NuGet Package manager console using the shortcut/cord alt T N O
. As a side note, you need to memorize this shortcut as it will save you a ton of time.
Step 6: Now let’s install the StaticFile Package so we can serve up our Angular App. install-package Microsoft.AspNetCore.StaticFiles
data:image/s3,"s3://crabby-images/8b62c/8b62cac5d9717bb27bb746691241311f2d93109f" alt=""
Step 7: Open Startup.cs and add the below code to the Configure method.
app.UseDefaultFiles(); app.UseStaticFiles();
data:image/s3,"s3://crabby-images/58382/58382a07b66f649a79e0641bad7a68bed09ad8c5" alt=""
Step 8: Let’s redirect to the root of the file when a 404 is encountered. This annoyance must be experienced to be appreciated. Add the below code.
app.Use(async (context, next) => { await next(); 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; await next(); } });
Right in-between app.UseMvc() and app.UseDefualtFiles() on the configure method in Startup.cs.
data:image/s3,"s3://crabby-images/40e62/40e621f94de8553a5a0d02492de929a132a5cc90" alt=""
Step 9: Open launchSettings.json and add the below settings. "launchBrowser": true, "launchUrl": "api/values", "environmentVariables": { "ASPNETCORE_ENVIRONMENT": "Development" }, "applicationUrl": "http://localhost:61278"
Note: Notice the comma after “Project”.
data:image/s3,"s3://crabby-images/6315c/6315c3e5899c31bbf30e4fa0e9e233cf904d3bc0" alt=""
Okay so let’s get Angular CLI Setup
Note: Keep in mind we are installing Angular on-top of WebApi.
Step 10: From the command line drill one level above where ever your webAPI.csproj file is located and execute the below. This is the CLI Angular app generation command.
note: Make sure you match the name of your Angular App to your webAPI folder. In my case, I am using testproj. Also, notice the red arrows. I am one level above my project folder.
ng new testproj
data:image/s3,"s3://crabby-images/b9ada/b9ada26facb55e678aa1ac7b46a3ceae2078127e" alt=""
Step 11: Rename the src folder to client-src.
data:image/s3,"s3://crabby-images/78789/7878997952716a5b76620191aa14ca307e1a1fe6" alt=""
Step 12: Open the file angular-cli.json and do the below edits. The outDir will make sure to copy the assets into the wwwroot directory.
"root": "client-src", "outDir": "wwwroot",
data:image/s3,"s3://crabby-images/77114/7711458f783f4ae1cc9431e71c439586f8aa46f7" alt=""
Okay, let build the Angular App and run this puppy!
Step 13: Lets compile the angular app by running ng build
.
data:image/s3,"s3://crabby-images/30f6b/30f6b9cf8fc930512334e897428dc0fd044300d9" alt=""
Step 14: Go back to Visual Studio and hit F5 and you should see the below page.
data:image/s3,"s3://crabby-images/dcac2/dcac2855ea3ac85059617ac6ae393223955a4fc6" alt=""