PowerShell App.Config

Вопрос задан: 11 лет назад Последняя активность: 1 год назад
up 25 down

Кто-нибудь работал, как заставить PowerShell использовать app.config файлы? У меня есть несколько .NET DLL, которые я хотел бы использовать в одном из моих сценариев, но они ожидают, что их собственные разделы конфигурации будут присутствовать в app.config/web.config.

3 ответа

Возможно, для Вашего проекта будут необходимы бесплатные векторные карты. На нашем сайте представлены карты для всех стран.

Реклама

up 36 down accepted

Перекрестные ссылки с этой темой, которые помогли мне с тем же вопросом: Дозвуковой доступ к строкам подключения App.Config из ссылочной DLL в скрипте Powershell

Я добавил следующее в свой скрипт, прежде чем вызывать DLL, которая нуждается в настройках конфигурации, где $ configpath - это местоположение файла, который я хочу загрузить:

[appdomain]::CurrentDomain.SetData("APP_CONFIG_FILE", $configpath)
Add-Type -AssemblyName System.Configuration

Увидеть этот сообщение, чтобы убедиться, что указанный файл конфигурации применяется к рабочему контексту.

up 6 down

Я предполагаю, что настройки должны быть в powershell.exe.config в каталоге powershell, но это плохой способ сделать что-то.

Вы можете использовать ConfigurationManager.OpenMappedExeConfiguration, чтобы открыть файл конфигурации, основанный на имени исполняемой DLL, а не на exe приложения, но для этого, очевидно, потребуются изменения в DLL.

up 2 down

Попытка нового ответа на старый вопрос.

Я думаю, что современный ответ будет: не делай этого. PowerShell - это оболочка. Обычным способом передачи информации между частями оболочки являются переменные оболочки. Для powershell это будет выглядеть так:

$global:MyComponent_MySetting = '12'
# i.e. 
$PSDefaultParameterValues
$ErrorActionPreference

Если ожидается, что настройки будут наследоваться через границы процессов, соглашение заключается в использовании переменных среды. Я распространяю это на настройки, которые пересекают границу C#/PowerShell. Пара примеров:

$env:PATH
$env:PSModulePath

Если вы думаете, что это анти-шаблон для .NET, вы можете пересмотреть. Это норма для приложений, размещаемых на сервере PAAS, и она станет новым значением по умолчанию для ASP.NET, работающего на оптимизированной для сервера среде CLR (ASP.NET v5).

Увидеть https://github.com/JabbR/JabbRv2/blob/dev/src/JabbR/Startup.cs#L21
Примечание: на момент написания статьи я ссылаюсь на .AddEnvironmentVariables()

Я несколько раз возвращался к этому вопросу, в том числе и сам. Я хотел сказать, что PowerShell не очень хорошо работает с <appSettings>. ИМО, в этом отношении гораздо лучше охватить аспект оболочки PS, чем аспект .NET.

Если вам нужна сложная конфигурация, возьмите строку JSON. POSH v3 + имеет ConvertFrom-JSON встроенный. Если все в вашем процессе использует одну и ту же сложную конфигурацию, поместите ее в файл .json и укажите на этот файл из переменной среды.

Если одного файла недостаточно, существуют хорошо зарекомендовавшие себя решения, такие как PATH шаблон, разрешение GIT .gitignore или разрешение ASP.NET web.config (здесь я не буду повторяться).

Ошибка 505

Что-то пошло не так

Попробуйте воспользоваться поиском