Прежде всего, мне ранее удавалось запустить одно из моих 64-битных тестовых веб-приложений на этой машине (когда я создавал прототип для этого проекта). Я работал в течение нескольких недель в 32-разрядной версии и понял, что мне нужно переключить приложение на 64-разрядную версию, и когда я это сделал (установил целевую платформу на x64 в проекте) и повторно развернул ее, оно перестало работать.
В прошлый раз мне потребовалось несколько дней, чтобы заставить работать 64-битную версию, и я не уверен, что мне не хватает на этот раз, как в прошлый раз.
Я публикую и отлаживаю под IIS.
Я получаю исключение BadImageFormatException с сообщением: "Не удалось загрузить файл или сборку "GEMS.Web" или одну из его зависимостей. Была предпринята попытка загрузить программу с неправильным форматом".
Это приложение ссылается как на 64-разрядные, так и на 32-разрядные сборки. Я установил для параметра «Включить 32-разрядные приложения» значение true в пуле приложений в IIS.
Я использую VS.NET 2012, IIS 7.5, работающий на 64-битной машине Win 7.
Следующее взято из трассировки загрузки сборки:
Assembly manager loaded from: C:\Windows\Microsoft.NET\Framework\v4.0.30319\clr.dll
Running under executable C:\Windows\SysWOW64\inetsrv\w3wp.exe
--- A detailed error log follows.
=== Pre-bind state information ===
LOG: User = XXXXXX\xxxxxx
LOG: DisplayName = GEMS.Web
(Partial)
WRN: Partial binding information was supplied for an assembly:
WRN: Assembly Name: GEMS.Web | Domain ID: 2
WRN: A partial bind occurs when only part of the assembly display name is provided.
WRN: This might result in the binder loading an incorrect assembly.
WRN: It is recommended to provide a fully specified textual identity for the assembly,
WRN: that consists of the simple name, version, culture, and public key token.
WRN: See whitepaper http://go.microsoft.com/fwlink/?LinkId=109270 for more information and common solutions to this issue.
LOG: Appbase = file:///c:/inetpub/wwwroot/GEMS.Web/
LOG: Initial PrivatePath = c:\inetpub\wwwroot\GEMS.Web\bin
Calling assembly : (Unknown).
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: c:\inetpub\wwwroot\GEMS.Web\web.config
LOG: Using host configuration file: C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet.config
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Policy not being applied to reference at this time (private, custom, partial, or location-based assembly bind).
LOG: Attempting download of new URL file:///C:/Windows/Microsoft.NET/Framework/v4.0.30319/Temporary ASP.NET Files/gems.web/eea5792e/72317e39/GEMS.Web.DLL.
LOG: Attempting download of new URL file:///C:/Windows/Microsoft.NET/Framework/v4.0.30319/Temporary ASP.NET Files/gems.web/eea5792e/72317e39/GEMS.Web/GEMS.Web.DLL.
LOG: Attempting download of new URL file:///c:/inetpub/wwwroot/GEMS.Web/bin/GEMS.Web.DLL.
ERR: Failed to complete setup of assembly (hr = 0x8007000b). Probing terminated.