Visual Studio (2010 - 2017) к сожалению не напрямую поддерживает его во время отладки, он предназначен только для публикации - даже с расширением SlowCheetah (помеченный ответ) он не работает для меня (только для проектов, использующих app.config, а не web.config).
Обратите внимание , что существует обходной путь , описанный в codeproject .
В нем описано, как изменить файл .msproj для перезаписи текущего файла web.config преобразованной версией.
Сначала я опишу этот обходной путь как Вариант 1 , но недавно я обнаружил еще один Вариант 2 , который проще в использовании (так что вы можете перейти к варианту 2 напрямую если хотите):
Вариант 1: Я добавил инструкции, взятые из исходной статьи codeproject (см. Ссылку выше), потому что снимки экрана там уже пропали, а я нет хочу потерять всю информацию:
VS.Net не выполняет никаких преобразований, когда вы разрабатываете и просто отлаживаете свою локальную среду. Но есть некоторые шаги, которые вы можете сделать, чтобы это произошло, если вы хотите.
- Во-первых, создайте необходимые конфигурации в VS.Net , предполагая, что отладки и выпуска по умолчанию недостаточно для того, что вы пытаетесь выполнить.
- Щелкните правой кнопкой мыши на
web.config
и выберите Добавить преобразования конфигурации - это создаст зависимый конфигурационный файл преобразования для каждой из определенных вами конфигураций.
- Теперь вы можете переименовать ваш
web.config
в web.base.config
.
- Добавьте
web.config
в ваш проект. Не имеет значения, что находится в нем, потому что оно будет перезаписываться каждый раз, когда мы делаем сборку, но мы хотим, чтобы это было частью проекта, поэтому VS.Net не дает нам "Ваш проект не настроен для отладки " всплывающее окно.
- Отредактируйте
.csproj
Файл проекта и добавьте следующую задачу TransformXml
к цели AfterBuild. Здесь вы можете видеть, что я буду преобразовывать файл web.base.config
, используя web.[configuration].config
, и он сохранит его как web.config
. Для получения подробной информации, пожалуйста, проверьте это Microsoft Q & A, а для получения инструкций о том, как расширить сборку, посмотрите там .
Вариант 2:
На основании этого ответа я разработал простое консольное приложение TransformConfig.exe (в синтаксисе C # 6.0):
using System;
using System.Linq;
using Microsoft.Web.XmlTransform;
namespace TransformConfig
{
class Program
{
static int Main(string[] args)
{
var myDocumentsFolder = $@"C:\Users\{Environment.UserName}\Documents";
var myVsProjects = $@"{myDocumentsFolder}\Visual Studio 2015\Projects";
string srcConfigFileName = "Web.config";
string tgtConfigFileName = srcConfigFileName;
string transformFileName = "Web.Debug.config";
string basePath = myVsProjects + @"\";
try
{
var numArgs = args?.Count() ?? 0;
if (numArgs == 0 || args.Any(x=>x=="/?"))
{
Console.WriteLine("\nTransformConfig - Usage:");
Console.WriteLine("\tTransformConfig.exe /d:tgtConfigFileName [/t:transformFileName [/s:srcConfigFileName][/b:basePath]]");
Console.WriteLine($"\nIf 'basePath' is just a directory name, '{basePath}' is preceeded.");
Console.WriteLine("\nTransformConfig - Example (inside PostBuild event):");
Console.WriteLine("\t\"c:\\Tools\\TransformConfig.exe\" /d:Web.config /t:Web.$(ConfigurationName).config /s:Web.Template.config /b:\"$(ProjectDir)\\\"");
Environment.ExitCode = 1;
return 1;
}
foreach (var a in args)
{
var param = a.Trim().Substring(3).TrimStart();
switch (a.TrimStart().Substring(0,2).ToLowerInvariant())
{
case "/d":
tgtConfigFileName = param ?? tgtConfigFileName;
break;
case "/t":
transformFileName = param ?? transformFileName;
break;
case "/b":
var isPath = (param ?? "").Contains("\\");
basePath = (isPath == false)
? $@"{myVsProjects}\" + param ?? ""
: param;
break;
case "/s":
srcConfigFileName = param ?? srcConfigFileName;
break;
default:
break;
}
}
basePath = System.IO.Path.GetFullPath(basePath);
if (!basePath.EndsWith("\\")) basePath += "\\";
if (tgtConfigFileName != srcConfigFileName)
{
System.IO.File.Copy(basePath + srcConfigFileName,
basePath + tgtConfigFileName, true);
}
TransformConfig(basePath + tgtConfigFileName, basePath + transformFileName);
Console.WriteLine($"TransformConfig - transformed '{basePath + tgtConfigFileName}' successfully using '{transformFileName}'.");
Environment.ExitCode = 0;
return 0;
}
catch (Exception ex)
{
var msg = $"{ex.Message}\nParameters:\n/d:{tgtConfigFileName}\n/t:{transformFileName}\n/s:{srcConfigFileName}\n/b:{basePath}";
Console.WriteLine($"TransformConfig - Exception occurred: {msg}");
Console.WriteLine($"TransformConfig - Processing aborted.");
Environment.ExitCode = 2;
return 2;
}
}
public static void TransformConfig(string configFileName, string transformFileName)
{
var document = new XmlTransformableDocument();
document.PreserveWhitespace = true;
document.Load(configFileName);
var transformation = new XmlTransformation(transformFileName);
if (!transformation.Apply(document))
{
throw new Exception("Transformation Failed");
}
document.Save(configFileName);
}
}
}
Убедитесь, что вы добавили DLL "C:\Program Files (x86)\MSBuild\Microsoft\VisualStudio\v14.0\Web\Microsoft.Web.XmlTransform.dll"
в качестве ссылки (этот пример относится к VS 2015, для более старых версий замените v14.0
в пути на соответствующий номер версии, например, v11.0
).
Для Visual Studio 2017, схема именования пути изменена: например, для корпоративной версии это здесь: C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\MSBuild\Microsoft\VisualStudio\v15.0\Web
.
Я предполагаю, что для профессиональной версии вам нужно заменить Enterprise
в пути на Professional
. Если вы используете предварительную версию, дополнительно замените 2017
на Preview
.
Скомпилируйте его и поместите файл .exe в каталог, например, C:\MyTools\
.
Использование:
Вы можете использовать его в своем событии после сборки (в свойствах проекта , выберите События сборки , затем отредактируйте Командную строку события после сборки ). Параметры командной строки (пример):
"C: \ MyTools \ TransformConfig.Exe" /d:Web.config /t:Web.$(ConfigurationName).config /s:Web.Template.config / b: "$ (ProjectDir) \"
т.е. сначала имя файла конфигурации, затем файл конфигурации преобразования, затем необязательный шаблон конфигурации, а затем путь к вашему проекту, содержащему оба файла.
Я добавил необязательный параметр конфигурации шаблона, поскольку в противном случае исходная полная конфигурация будет перезаписана преобразованием, чего можно избежать, предоставив шаблон.
Создайте шаблон, просто скопировав исходный файл Web.config и назовите его Web.Template.config.
Примечание:
Если вы предпочитаете, вы также можете скопировать файл TransformConfig.exe
в путь Visual Studio, упомянутый выше, где находится Microsoft.Web.XmlTransform.dll
, и ссылаться на него во всех ваших проектах, где вам нужно преобразовать свои конфигурации.
Для тех из вас, кто интересуется, почему я добавил назначения Environment.ExitCode = x;
: простой возврат int из Main не помог в событии build. Подробнее здесь.
Если вы публикуете свой проект и используете Web.Template.config, убедитесь, что вы выполнили rebuild в своем решении с правильной конфигурацией (обычно Release), прежде чем публиковать. Причина в том, что Web.Config перезаписывается во время отладки, и в противном случае вы можете преобразовать неправильный файл.