在经历了一些冗长而复杂的故事之后,我发现了与此非常相似的代码,并且几个月来一直在使用它。昨天我改变了很多东西,现在这段代码不再工作了。
public void OpenConfig(string configDir)
{
if (string.IsNullOrWhiteSpace(configDir))
{
configDir = AppDomain.CurrentDomain.BaseDirectory;
}
var sharedConfigPath = Path.Combine(configDir, ConfigFileName);
var map = new ExeConfigurationFileMap { ExeConfigFilename = sharedConfigPath };
sharedConfig = ConfigurationManager.OpenMappedExeConfiguration(map, ConfigurationUserLevel.None);
logger.Trace("'{0}' set 'SharedConfigPath' to '{1}'.", GetType().Name, sharedConfig.FilePath);
}
然后,我得到这样的配置值:
ServicePollingInterval = GetIntegerAppSetting("ServicePollingInterval"),
在哪里
private static int GetIntegerAppSetting(string settingName, bool throwOnMissing = false)
{
string setting = null;
if (settingTag != null)
var settingTag = sharedConfig.AppSettings.Settings[settingName];
{
setting = settingTag.Value;
}
if (setting == null)
{
if (throwOnMissing)
{
logger.Trace("App Setting '{0}' not configured. Throwing an exception.", settingName);
throw new EalsConfigurationException(settingName, "App Setting not configured.");
}
logger.Trace("App Setting '{0}' not configured. Defaulting to -1.", settingName);
return -1;
}
int i;
if (!int.TryParse(setting, out i))
{
logger.Trace("App Setting '{0}' not valid as Integer. Throwing an exception.", settingName);
throw new EalsConfigurationException(setting, "App Setting '{0}' not valid as Integer.");
}
return i;
}
但是,现在基本上在一夜之间,调用var settingTag = sharedConfig.AppSettings.Settings[settingName];
返回settingTag
为 null,因为该集合中没有appSettings
项目。
我已经在这个项目上工作了几个月,我把这个配置代码放在一开始,因为我有几个可执行文件在同一个文件夹中运行,我希望它们都使用相同的配置。我真的很难过(并不感到惊讶)我没有对配置进行任何令人难忘的代码更改。
谁能看到我可能搞砸了什么,或者猜测我可能改变了哪些外部影响,或者任何可能突然导致这个Configuration
对象的所有部分都变空的事情。
我有但无法追踪的一个怀疑是该应用程序运行的用户发生了变化。这很复杂:我有一个托管在 Windows 服务中的 WCF 服务,由 WPF 应用程序使用。