Equivalent to ‘app.config’ for a library (DLL)

You can have separate configuration file, but you’ll have to read it “manually”, the ConfigurationManager.AppSettings["key"] will read only the config of the running assembly.

Assuming you’re using Visual Studio as your IDE, you can right click the desired project → Add → New item → Application Configuration File

This will add App.config to the project folder, put your settings in there under <appSettings> section. In case you’re not using Visual Studio and adding the file manually, make sure to give it such name: DllName.dll.config, otherwise the below code won’t work properly.

Now to read from this file have such function:

string GetAppSetting(Configuration config, string key)
{
    KeyValueConfigurationElement element = config.AppSettings.Settings[key];
    if (element != null)
    {
        string value = element.Value;
        if (!string.IsNullOrEmpty(value))
            return value;
    }
    return string.Empty;
}

And to use it:

Configuration config = null;
string exeConfigPath = this.GetType().Assembly.Location;
try
{
    config = ConfigurationManager.OpenExeConfiguration(exeConfigPath);
}
catch (Exception ex)
{
    //handle errror here.. means DLL has no sattelite configuration file.
}

if (config != null)
{
    string myValue = GetAppSetting(config, "myKey");
    ...
}

You’ll also have to add reference to System.Configuration namespace in order to have the ConfigurationManager class available.

When building the project, in addition to the DLL you’ll have DllName.dll.config file as well, that’s the file you have to publish with the DLL itself.

Within the VS project, you should set the .config file “Copy to output directory” setting to “Always Copy”.

The above is basic sample code, for those interested in a full scale example, please refer to this other answer.

Leave a Comment