VSTO Debug version fine fine, Installed version nie czyta app.config
Mam dodatek VSTO Excel 2007, który powinien odczytać ciągi połączeń z pliku app.config, a następnie pozwolić użytkownikowi zdecydować, z którą bazą danych się połączyć. Działa to dobrze, gdy go debuguję, ale gdy uruchomię wdrożoną wersję (wykonaną za pomocą Instalatora Windows), połączenia nie są w ogóle odczytywane. Dodałem podstawowe wyniki ze wszystkich projektów do projektu instalacji. Plik app.config znajduje się w projekcie ExcelAddIn, ale nie pod nagłówkiem Excel. Klasa zarządzająca łańcuchami połączeń znajduje się w innym projekcie.
Oto mój plik app.config:
<?xml version="1.0"?>
<configuration>
<configSections>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=4.4.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false"/>
</configSections>
<connectionStrings>
<clear/>
<add name="MyEntities" connectionString="metadata=res://*/MyModel.csdl|res://*/MyModel.ssdl|res://*/SymModel.msl;provider=System.Data.SqlClient;provider connection string="data source=myServer;initial catalog=myDB;persist security info=True;user id=myUser;password=myPassword;multipleactiveresultsets=True;App=EntityFramework"" providerName="System.Data.EntityClient"/>
</connectionStrings>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="v11.0"/>
</parameters>
</defaultConnectionFactory>
</entityFramework>
<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/></startup></configuration>
Używam następujących elementów, aby przejść do elementów połączenia:
System.Configuration.Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
ConnectionStringsSection csSection = config.ConnectionStrings;
Próbowałem dodać plik ExcelAddin.dll.config do folderu projektu instalacji, w którym znajduje się folder Release i plik .proj. Ustawiłem właściwość „Copy to Output Directory” pliku app.config na „Copy always” i właściwość Build Action na „Content”.
Czy jest coś niepokojącego w moim pliku app.config lub dlaczego nie jest on pobierany (ciągi połączeń nie są ładowane do csSection) po uruchomieniu instalatora?