2016-08-22 6 views
2

У меня есть служба WCF, размещенная в IIS, и служба работает нормально. Фактически он использует следующие файлы Global.asax и OrderService.svc в порядке.Пользовательский Factory ServiceHost не может быть загружен из GAC

<%@ Application Codebehind="Global.asax.cs" Inherits="MyCompany.MyOrderServices.Global" Language="C#" %> 

<%@ ServiceHost Language="C#" Debug="true" Service="MyCompany.ServiceLibrary.OrderServiceImpl" Factory="MyCompany.ServiceLibrary.GenericServiceHostFactoryImpl, MyCompany.ServiceLibrary"%> 

Я пытаюсь сделать \ bin \ 'меньше службы WCF и разместить его в IIS. Я поставил все необходимые сборки в GAC. Когда я делаю запрос к сервису я получаю следующее сообщение об ошибке:

Parser Error

Description: An error occurred during the parsing of a resource required to service this request. Please review the following specific parse error details and modify your source file appropriately.

Parser Error Message: Could not load the assembly 'MyCompany.MyOrderServices'. Make sure that it is compiled before accessing the page.

Source File: /global.asax Line: 1

Ну, я исправил эту ошибку, изменяя Global.asax файл, как показано ниже:

<%@ Application Codebehind="Global.asax.cs" Inherits="MyCompany.MyOrderServices.Global, MyCompany.MyOrderServices, Version=1.0.0.0, Culture=neutral, PublicKeyToken=XXXXXXXXXXX" Language="C#" %> 

Таким образом я получил точку: я пришлось менять имена простых типов в именах классов, соответствующих их сборке. Фактически после исправления ошибки Global.asax, я получаю следующую ошибку.

Could not load file or assembly 'MyCompany.ServiceLibrary' or one of its dependencies. The system cannot find the file specified.

Затем я включил ведение журнала Fusion и получил информацию ниже:

=== Pre-bind state information ===

LOG: DisplayName = MyCompany.ServiceLibrary

(Partial)

WRN: Partial binding information was supplied for an assembly:

WRN: Assembly Name: MyCompany.ServiceLibrary | Domain ID: 4

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:/OrderServicePublish/

LOG: Initial PrivatePath = C:\OrderServicePublish\bin

Calling assembly : (Unknown).

===

LOG: This bind starts in default load context.

LOG: Using application configuration file: C:\OrderServicePublish\web.config

LOG: Using host configuration file: C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet.config

LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework64\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/Framework64/v4.0.30319/Temporary ASP.NET Files/root/98694738/2a3c07d8/MyCompany.MyServiceLibrary.DLL.

LOG: Attempting download of new URL file:///C:/Windows/Microsoft.NET/Framework64/v4.0.30319/Temporary ASP.NET Files/root/98694738/2a3c07d8/MyCompany.MyServiceLibrary/MyCompany.MyServiceLibrary.DLL.

LOG: Attempting download of new URL file:///C:/OrderServicePublish/bin/MyCompany.MyServiceLibrary.DLL.

LOG: Attempting download of new URL file:///C:/OrderServicePublish/bin/MyCompany.MyServiceLibrary/MyCompany.MyServiceLibrary.DLL.

LOG: Attempting download of new URL file:///C:/Windows/Microsoft.NET/Framework64/v4.0.30319/Temporary ASP.NET Files/root/98694738/2a3c07d8/MyCompany.MyServiceLibrary.EXE.

LOG: Attempting download of new URL file:///C:/Windows/Microsoft.NET/Framework64/v4.0.30319/Temporary ASP.NET Files/root/98694738/2a3c07d8/MyCompany.MyServiceLibrary/MyCompany.MyServiceLibrary.EXE.

LOG: Attempting download of new URL file:///C:/OrderServicePublish/bin/MyCompany.MyServiceLibrary.EXE.

LOG: Attempting download of new URL file:///C:/OrderServicePublish/bin/MyCompany.MyServiceLibrary/MyCompany.MyServiceLibrary.EXE.

Видимо GAC папки опущен. Затем я изменил файл .svc, как показано ниже:

<%@ ServiceHost Language="C#" Debug="true" Service="MyCompany.ServiceLibrary.OrderServiceImpl, MyCompany.ServiceLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=XXXXXXXXXXX" Factory="MyCompany.ServiceLibrary.GenericServiceHostFactoryImpl, MyCompany.ServiceLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=XXXXXXXXXXX"%> 

... Но у меня такая же ошибка. В чем проблема с директивой ServiceHost. Почему сборка не может быть загружена из папок GAC?

(Примечание1. Кстати, я проверил следующие ссылки, предполагающие изменить простые имена типов в имена квалифицирован сборного типа, но он не работал для меня

1) https://social.msdn.microsoft.com/Forums/vstudio/en-US/3c61739c-b1fe-46bd-b8eb-8e9485f8891b/wcf-service-without-bin-folder?forum=wcf

2) http://answers.flyppdevportal.com/categories/sharepoint2010/sharepoint2010programming.aspx?ID=7b968dc5-4522-4896-8684-34064f0baaf5)

+0

Вы вручную проверили сборку с именем, версией, сильным именем и культурой в GAC, потому что если есть несоответствие, она не будет загружать сборку –

+0

Да @ mrinal-kamboj Я проверил GAC для сборки, и он просто там :) – rebulanyum

+0

Можете ли вы попробовать одно и то же репо с консольным приложением, все останется таким же, если он загрузится с GAC, я просто пытаюсь сузить до актуальной проблемы в среде. Пожалуйста, убедитесь, что в системе нет другой копии (PATH), где она загружается. –

ответ

0

Hah!

Похоже, я забыл изменить Web.config: он также содержит имена сборок.

<system.webServer> 
    <modules runAllManagedModulesForAllRequests="true"> 
    <add name="CORSEnablingModule" type="MyCompany.ServiceLibrary.Cors.CORSEnablingModule, MyCompany.ServiceLibrary" /> 
    </modules> 
</system.webServer> 

Теперь я изменил его на полностью квалифицированное имя, и все в порядке.

Спасибо в любом случае.

+0

Да, но это то, что вы редактируете в web.config, помогли правильно загрузить сборку с GAC, пожалуйста, обновите. Вот почему было предложение относительно консоли, поскольку у нее нет Web.Config. –