ELMAH 1.2 не может загрузить файл или сборку 'System.Data.SQLite' или одну из ее зависимостей - PullRequest
2 голосов
/ 19 октября 2011

Я пытаюсь включить 64-разрядную версию ELMAH 1.2 в приложение ASP.NET, которое размещается локально в IIS Express. Я ссылался на версию Elmah.dll, чтобы она копировалась в папку bin. В целях настройки локальной рабочей станции я хочу записывать исключения только в файлы XML. В результате я настроил ELMAH следующим образом:

<configuration>
    <sectionGroup name="elmah">
       <section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah" />
    </sectionGroup>

    <elmah>
       <errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="C:\Logs\Elmah" />
    </elmah>

    <system.webServer>
       <handlers>
          <add name="Elmah" path="elmah.axd" verb="POST,GET,HEAD" type="Elmah.ErrorLogPageFactory, Elmah" preCondition="integratedMode" />
       </handlers>
       <modules>
          <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" preCondition="managedHandler" />
       </modules>
    </system.webServer>
</configuration>

Когда я запускаю сеанс отладки из Visual Studio, сайт загружается, и я получаю следующую ошибку времени выполнения:

Не удалось загрузить файл или сборку 'System.Data.SQLite' или одну из ее зависимостей. Была предпринята попытка загрузить программу с неверным форматом.

Трассировка стека выглядит следующим образом:

[BadImageFormatException: Could not load file or assembly 'System.Data.SQLite' or one of its dependencies. An attempt was made to load a program with an incorrect format.]
System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) +0
System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) +60
System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection, Boolean suppressSecurityChecks) +555
System.Reflection.RuntimeAssembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection) +308
System.Reflection.Assembly.Load(String assemblyString) +51
System.Web.Configuration.CompilationSection.LoadAssemblyHelper(String assemblyName, Boolean starDirective) +115

[ConfigurationErrorsException: Could not load file or assembly 'System.Data.SQLite' or one of its dependencies. An attempt was made to load a program with an incorrect format.]
System.Web.Configuration.CompilationSection.LoadAssemblyHelper(String assemblyName, Boolean starDirective) +1031
System.Web.Configuration.CompilationSection.LoadAllAssembliesFromAppDomainBinDirectory() +346
System.Web.Configuration.CompilationSection.LoadAssembly(AssemblyInfo ai) +85
System.Web.Configuration.AssemblyInfo.get_AssemblyInternal() +54
System.Web.Compilation.BuildManager.GetReferencedAssemblies(CompilationSection compConfig) +274
System.Web.Compilation.BuildManager.GetPreStartInitMethodsFromReferencedAssemblies() +64
System.Web.Compilation.BuildManager.CallPreStartInitMethods() +235
System.Web.Hosting.HostingEnvironment.Initialize(ApplicationManager appManager, IApplicationHost appHost, IConfigMapPathFactory configMapPathFactory, HostingEnvironmentParameters hostingParameters, PolicyLevel policyLevel, Exception appDomainCreationException) +1107

[HttpException (0x80004005): Could not load file or assembly 'System.Data.SQLite' or one of its dependencies. An attempt was made to load a program with an incorrect format.]
System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +763
System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +156
System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +243

Вопрос в том, почему ELMAH заставляет среду выполнения пытаться загрузить System.Data.SQLite, поскольку я не хочу использовать SQLite для регистрации исключения? Кроме того, как я могу решить эту проблему (я смотрел везде в группе Google ELMAH и уже в StackOverflow)?

1 Ответ

1 голос
/ 20 октября 2011

Это не проблема с Elmah или SQLite, проблема в том, что IISExpress работает на вашем компьютере в 32-битной версии.Вам нужно будет запустить 32-разрядную версию для своего настольного компьютера, 64-разрядная версия подойдет для производства.

Проверьте это: http://learn.iis.net/page.aspx/1010/iis-75-express-readme/, особенно:

И 32-разрядная, иПоддерживаются 64-разрядные системы, однако существует только 32-разрядная сборка IIS 7.5 Express.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...