9.4 KiB
title | author | description | ms.author | manager | ms.custom | ms.date | ms.topic | ms.technology | ms.prod | uid |
---|---|---|---|---|---|---|---|---|---|---|
Using IIS modules with ASP.NET Core | guardrex | Reference document describing active and inactive IIS modules for ASP.NET Core applications. | riande | wpickett | mvc | 03/08/2017 | article | aspnet | aspnet-core | host-and-deploy/iis/modules |
Using IIS Modules with ASP.NET Core
By Luke Latham
ASP.NET Core applications are hosted by IIS in a reverse proxy configuration. Some of the native IIS modules and all of the IIS managed modules aren't available to process requests for ASP.NET Core apps. In many cases, ASP.NET Core offers an alternative to the features of IIS native and managed modules.
Native Modules
Module | .NET Core Active | ASP.NET Core Option |
---|---|---|
Anonymous AuthenticationAnonymousAuthenticationModule |
Yes | |
Basic AuthenticationBasicAuthenticationModule |
Yes | |
Client Certification Mapping AuthenticationCertificateMappingAuthenticationModule |
Yes | |
CGICgiModule |
No | |
Configuration ValidationConfigurationValidationModule |
Yes | |
HTTP ErrorsCustomErrorModule |
No | Status Code Pages Middleware |
Custom LoggingCustomLoggingModule |
Yes | |
Default DocumentDefaultDocumentModule |
No | Default Files Middleware |
Digest AuthenticationDigestAuthenticationModule |
Yes | |
Directory BrowsingDirectoryListingModule |
No | Directory Browsing Middleware |
Dynamic CompressionDynamicCompressionModule |
Yes | Response Compression Middleware |
TracingFailedRequestsTracingModule |
Yes | ASP.NET Core Logging |
File CachingFileCacheModule |
No | Response Caching Middleware |
HTTP CachingHttpCacheModule |
No | Response Caching Middleware |
HTTP LoggingHttpLoggingModule |
Yes | ASP.NET Core Logging Implementations: elmah.io, Loggr, NLog, Serilog |
HTTP RedirectionHttpRedirectionModule |
Yes | URL Rewriting Middleware |
IIS Client Certificate Mapping AuthenticationIISCertificateMappingAuthenticationModule |
Yes | |
IP and Domain RestrictionsIpRestrictionModule |
Yes | |
ISAPI FiltersIsapiFilterModule |
Yes | Middleware |
ISAPIIsapiModule |
Yes | Middleware |
Protocol SupportProtocolSupportModule |
Yes | |
Request FilteringRequestFilteringModule |
Yes | URL Rewriting Middleware IRule |
Request MonitorRequestMonitorModule |
Yes | |
URL RewritingRewriteModule |
Yes† | URL Rewriting Middleware |
Server Side IncludesServerSideIncludeModule |
No | |
Static CompressionStaticCompressionModule |
No | Response Compression Middleware |
Static ContentStaticFileModule |
No | Static File Middleware |
Token CachingTokenCacheModule |
Yes | |
URI CachingUriCacheModule |
Yes | |
URL AuthorizationUrlAuthorizationModule |
Yes | ASP.NET Core Identity |
Windows AuthenticationWindowsAuthenticationModule |
Yes |
†The URL Rewrite Module's isFile
and isDirectory
don't work with ASP.NET Core apps due to the changes in directory structure.
Managed Modules
Module | .NET Core Active | ASP.NET Core Option |
---|---|---|
AnonymousIdentification | No | |
DefaultAuthentication | No | |
FileAuthorization | No | |
FormsAuthentication | No | Cookie Authentication Middleware |
OutputCache | No | Response Caching Middleware |
Profile | No | |
RoleManager | No | |
ScriptModule-4.0 | No | |
Session | No | Session Middleware |
UrlAuthorization | No | |
UrlMappingsModule | No | URL Rewriting Middleware |
UrlRoutingModule-4.0 | No | ASP.NET Core Identity |
WindowsAuthentication | No |
IIS Manager application changes
Using IIS Manager to configure settings, the web.config file of the app is changed. If deploying an app and including web.config, any changes made with IIS Manger are overwritten by the deployed web.config file. If changes are made to the server's web.config file, copy the updated web.config file to the local project immediately.
Disabling IIS modules
If an IIS module is configured at the server level that must be disabled for an app, an addition to the app's web.config file can disable the module. Either leave the module in place and deactivate it using a configuration setting (if available) or remove the module from the app.
Module deactivation
Many modules offer a configuration setting that allows them to be disabled them without removing them from the app. This is the simplest and quickest way to deactivate a module. For example if wishing to disable the IIS URL Rewrite Module, use the <httpRedirect>
element as shown below. For more information on disabling modules with configuration settings, follow the links in the Child Elements section of IIS <system.webServer>
.
<configuration>
<system.webServer>
<httpRedirect enabled="false" />
</system.webServer>
</configuration>
Module removal
If opting to remove a module with a setting in web.config, unlock the module and unlock the <modules>
section of web.config first. The steps are outlined below:
-
Unlock the module at the server level. Click on the IIS server in the IIS Manager Connections sidebar. Open the Modules in the IIS area. Click on the module in the list. In the Actions sidebar on the right, click Unlock. Unlock as many modules as are planned to remove from web.config later.
-
Deploy the app without a
<modules>
section in web.config. If an app is deployed with a web.config containing the<modules>
section without having unlocked the section first in the IIS Manager, the Configuration Manager throws an exception when attempting to unlock the section. Therefore, deploy the app without a<modules>
section. -
Unlock the
<modules>
section of web.config. In the Connections sidebar, click the website in Sites. In the Management area, open the Configuration Editor. Use the navigation controls to select thesystem.webServer/modules
section. In the Actions sidebar on the right, click to Unlock the section. -
At this point, a
<modules>
section can be added to the web.config file with a<remove>
element to remove the module from the app. Multiple<remove>
elements can be added to remove multiple modules. Don't forget that if web.config changes are made on the server to make them immediately in the project locally. Removing a module this way won't affect the use of the module with other apps on the server.
<configuration>
<system.webServer>
<modules>
<remove name="MODULE_NAME" />
</modules>
</system.webServer>
</configuration>
For an IIS installation with the default modules installed, use the following <module>
section to remove the default modules.
<modules>
<remove name="CustomErrorModule" />
<remove name="DefaultDocumentModule" />
<remove name="DirectoryListingModule" />
<remove name="HttpCacheModule" />
<remove name="HttpLoggingModule" />
<remove name="ProtocolSupportModule" />
<remove name="RequestFilteringModule" />
<remove name="StaticCompressionModule" />
<remove name="StaticFileModule" />
</modules>
An IIS module can also be removed with Appcmd.exe. Provide the MODULE_NAME
and APPLICATION_NAME
in the command shown below:
Appcmd.exe delete module MODULE_NAME /app.name:APPLICATION_NAME
Here's how to remove the DynamicCompressionModule
from the Default Web Site:
%windir%\system32\inetsrv\appcmd.exe delete module DynamicCompressionModule /app.name:"Default Web Site"
Minimum module configuration
The only modules required to run an ASP.NET Core app are the Anonymous Authentication Module and the ASP.NET Core Module.