Run and debug ASP.NET Core apps in IIS Express
warning
Running and debugging ASP.NET Core apps in IIS Express only works on Windows.
To host ASP.NET Core applications, IIS Express relies on the ASP.NET Core Module. You can install the required components in the following order:
Internet Information Services — Windows button | Turn Windows features on or off.
note
If you install IIS after the Hosting Bundle, you will need to run the Hosting Bundle installer to repair the installation.
You can check if you have the module in your IIS Express configuration file %
\PROGRAMFILES(x86)% . If there is at least one of the following lines, then you have the module installed:\IIS Express \config \templates \PersonalWebServer \applicationhost.config <add name="AspNetCoreModule"... <add name="AspNetCoreModuleV2"...
If everything is configured correctly, JetBrains Rider will automatically find all necessary components. You can check their paths on the Build, Execution, Deployment | IIS Express page of JetBrains Rider settings CtrlAlt0S:
tip
In case IIS Express does not start or returns an empty error, there is a chance the .NET Core Hosting Bundle did not install correctly. This article (under Fixing the applicationhost.config template) may help troubleshoot and fix the default IIS Express configuration template on your machine.
After creating a new ASP.NET Core project or loading an existing one that has a launchSettings.json file with one or more IIS Express profiles, JetBrains Rider will automatically create run/debug configurations based on those profiles.
You can view and edit created configurations either in the Run/Debug Configurations dialog (Run | Edit Configurations) or on the toolbar selector:
data:image/s3,"s3://crabby-images/a223c/a223c8c18dd1c433c4465722555b8054d9571da8" alt="JetBrains Rider: IIS Express run configuration JetBrains Rider: IIS Express run configuration"
For IIS Express profiles, the run configuration includes a few additional options:
Generate applicationhost.config | To launch IIS Express with your ASP.NET Core application, JetBrains Rider uses a configuration file .idea |
Show IIS Express output | This option enables output from the IIS Express process. By default, it is disabled (as the output is quite verbose), but when enabled we can see additional details when running the application: ![]() |
Send debug request | When this option is enabled, JetBrains Rider will send an initial request (with a |
Additional IIS Express arguments | This field lets you pass additional arguments to the IIS Express host (for example, to enable request tracing). |
As with other launchSettings-based run configurations, you can specify the target framework and additional runtime arguments using this dialog, but some IIS Express-specific options should be configured directly in the launchSettings.json file.
Once everything is installed and configured, you can run your project CtrlF5 or set breakpoints (even in application startup, for example in Configure
/ConfigureServices
methods) and then debug your code AltF5.
For launchSettings-based run configurations, JetBrains Rider will check whether an ASP.NET Core developer certificate or IIS Express self-signed certificate is set up on your machine. If not, you will see a notification which also lets you generate one:
data:image/s3,"s3://crabby-images/168eb/168ebc1f0d5e53c828be02f95a8863d7263b4b5c" alt="JetBrains Rider: Generating a self-signed SSL certificate JetBrains Rider: Generating a self-signed SSL certificate"
Setting up a certificate can be done from that warning, or with the Set up certificate action, which you can find using Find Action Ctrl0Q.
For ASP.NET Core, JetBrains Rider will use the dotnet dev-certs https
command to check whether the certificate has been installed. For IIS Express, it will check the http.sys certificate settings (similar to the netsh http show sslcert
command line).
It also verifies the certificate is trusted by our system. This should make it easier to develop ASP.NET and ASP.NET Core web applications that make use of SSL on our developer machine.