How to deploy angular-cli app on iis
Here is how I solve this situation;
- Create project with angular-cli
- Build your application with
ng build
- Open IIS, create new virtual directory and show
dist
folder - Set
base href
in your index.html from/
to/yourAliasNameOnIIS
Use this web.config for redirecting requests to your index.html page
<system.webServer><rewrite> <rules> <rule name="AngularJS Routes" stopProcessing="true"> <match url=".*" /> <conditions logicalGrouping="MatchAll"> <add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" /> <add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" /> <add input="{REQUEST_URI}" pattern="^/(api)" negate="true" /> </conditions> <action type="Rewrite" url="/yourAliasNameOnIIS" /> </rule> </rules></rewrite>
Convert your virtual directory to a web application
You can also use ng build --deploy-url "/yourAliasNameOnIIS"
to change src path in dist/index.html
.
I hope it helps!
When you open the dev tools of your browser, you would have seen 404 messages when the app was trying to donwload the js, css etc files
You need to set the base href in index.html to
<base href="./">
this will make sure the base ref is relative to where your website lives in IIS.You also need to use hash location strategy otherwise, IIS will intercept your ng2 router URL changes and try to find a controller/action for the URL.
under the imports of your app.module.ts:
RouterModule.forRoot(routerConfig, { useHash: true })
I have done these 2 steps and all is working perfectly on Azure VM with IIS. Doing it this way also means it you do not have to put your SPA on the root and you can have multiple SPA's running happily next to each other (in different websites on IIS)
For me, it was very simple:
- Run the ng build command. It will generate the dist folder.
- Make href="" in the index.html file.
- Give the dist folder path to IIS application and it will work.
This makes it even simpler, you do not need to modify the index.html file:
ng build -prod --base-href