---
title: Transform web.config
author: guardrex
description: Learn how to transform the web.config file when publishing an ASP.NET Core app.
monikerRange: '>= aspnetcore-2.2'
ms.author: riande
ms.custom: mvc
ms.date: 10/07/2019
uid: host-and-deploy/iis/transform-webconfig
---
# Transform web.config
By [Vijay Ramakrishnan](https://github.com/vijayrkn) and [Luke Latham](https://github.com/guardrex)
Transformations to the *web.config* file can be applied automatically when an app is published based on:
* [Build configuration](#build-configuration)
* [Profile](#profile)
* [Environment](#environment)
* [Custom](#custom)
These transformations occur for either of the following *web.config* generation scenarios:
* Generated automatically by the `Microsoft.NET.Sdk.Web` SDK.
* Provided by the developer in the [content root](xref:fundamentals/index#content-root) of the app.
## Build configuration
Build configuration transforms are run first.
Include a *web.{CONFIGURATION}.config* file for each [build configuration (Debug|Release)](/dotnet/core/tools/dotnet-publish#options) requiring a *web.config* transformation.
In the following example, a configuration-specific environment variable is set in *web.Release.config*:
```xml
```
The transform is applied when the configuration is set to *Release*:
```dotnetcli
dotnet publish --configuration Release
```
The MSBuild property for the configuration is `$(Configuration)`.
## Profile
Profile transformations are run second, after [Build configuration](#build-configuration) transforms.
Include a *web.{PROFILE}.config* file for each profile configuration requiring a *web.config* transformation.
In the following example, a profile-specific environment variable is set in *web.FolderProfile.config* for a folder publish profile:
```xml
```
The transform is applied when the profile is *FolderProfile*:
```dotnetcli
dotnet publish --configuration Release /p:PublishProfile=FolderProfile
```
The MSBuild property for the profile name is `$(PublishProfile)`.
If no profile is passed, the default profile name is **FileSystem** and *web.FileSystem.config* is applied if the file is present in the app's content root.
## Environment
Environment transformations are run third, after [Build configuration](#build-configuration) and [Profile](#profile) transforms.
Include a *web.{ENVIRONMENT}.config* file for each [environment](xref:fundamentals/environments) requiring a *web.config* transformation.
In the following example, a environment-specific environment variable is set in *web.Production.config* for the Production environment:
```xml
```
The transform is applied when the environment is *Production*:
```dotnetcli
dotnet publish --configuration Release /p:EnvironmentName=Production
```
The MSBuild property for the environment is `$(EnvironmentName)`.
When publishing from Visual Studio and using a publish profile, see .
The `ASPNETCORE_ENVIRONMENT` environment variable is automatically added to the *web.config* file when the environment name is specified.
## Custom
Custom transformations are run last, after [Build configuration](#build-configuration), [Profile](#profile), and [Environment](#environment) transforms.
Include a *{CUSTOM_NAME}.transform* file for each custom configuration requiring a *web.config* transformation.
In the following example, a custom transform environment variable is set in *custom.transform*:
```xml
```
The transform is applied when the `CustomTransformFileName` property is passed to the [dotnet publish](/dotnet/core/tools/dotnet-publish) command:
```dotnetcli
dotnet publish --configuration Release /p:CustomTransformFileName=custom.transform
```
The MSBuild property for the profile name is `$(CustomTransformFileName)`.
## Prevent web.config transformation
To prevent transformations of the *web.config* file, set the MSBuild property `$(IsWebConfigTransformDisabled)`:
```dotnetcli
dotnet publish /p:IsWebConfigTransformDisabled=true
```
## Additional resources
* [Web.config Transformation Syntax for Web Application Project Deployment](https://go.microsoft.com/fwlink/?LinkId=301874)
* [Web.config Transformation Syntax for Web Project Deployment Using Visual Studio](https://docs.microsoft.com/previous-versions/aspnet/dd465326(v=vs.110))