Проблемы с миграцией .Net Remoting из Framework 2 на 4 - PullRequest
2 голосов
/ 01 марта 2012

В настоящее время у меня есть приложение .Net Remoting, работающее на Framework 2 под IIS.Я должен обновить его до Framework 4, чтобы использовать некоторые новые компоненты.Мне удалось все настроить и запустить гладко на Framework 2, но как только я перехожу на Framework 4, я получаю следующее исключение при попытке вызвать одну из функций моего удаленного объекта.

The input stream is not a valid binary format. 
The starting contents (in bytes) are: 
53-79-73-74-65-6D-2E-52-75-6E-74-69-6D-65-2E-52-65 ...

Эта ошибка не является реальной ошибкой, она вызвана тем, что удаленный объект вызывает исключение, а IIS оборачивает исключение в XML, что приводит к отключению BinaryFormatter. См. Это для получения дополнительной информации об ошибке .

Это очень прискорбно, потому что я не могу видеть, что вызывает исключение, и никогда ранее не использовал Remoting, у меня не так много идей, какгде начать отладку.Похоже, что исключение выдается еще до того, как я вхожу в код, потому что я веду немало журналирования, и, похоже, ничего из этого не срабатывает.

По сути, я ищу некоторые подсказки или указатели от людей, которые столкнулисьпохожие проблемы:

  • Что может быть причиной исключения, если код не изменился, кроме компиляции из .Net 2 в .Net 4?
  • Как получить полное сообщение об исключении, котороевернулся?

Вот код, который получает удаленный объект

Dim clientProvider As BinaryClientFormatterSinkProvider = New BinaryClientFormatterSinkProvider()
Dim serverProvider As BinaryServerFormatterSinkProvider = New BinaryServerFormatterSinkProvider()
serverProvider.TypeFilterLevel = System.Runtime.Serialization.Formatters.TypeFilterLevel.Full

tsChannelName = System.Guid.NewGuid().ToString()

Dim props As IDictionary = New Hashtable()
props("port") = 0
props("name") = tsChannelName
props("typeFilterLevel") = System.Runtime.Serialization.Formatters.TypeFilterLevel.Full
props("secure") = True
props("useDefaultCredentials") = True

Dim Channel As HttpChannel = New HttpChannel(props, clientProvider, serverProvider)

ChannelServices.RegisterChannel(Channel, False)

//Get the object on the Server
Dim rtnComm As I_CMQCComm = Activator.GetObject(GetType(I_CMQCComm), server)

//Knock knock
rtnComm.IsAlive() 'Exception is thrown here

Я могу предоставить дополнительную информацию по мере необходимости.

1 Ответ

0 голосов
/ 01 марта 2012

Хорошо!

Прежде всего, чтобы увидеть ошибку, рекомендуется изменить используемый форматер, чтобы можно было увидеть всю ошибку.

По сути, у меня был недоступен сервер, и IIS отправлял обратно HTML, который был сброшен с Formatter.

Как увидеть ошибку:

Dim clientProvider As SoapClientFormatterSinkProvider = New SoapClientFormatterSinkProvider()
Dim serverProvider As SoapServerFormatterSinkProvider = New SoapServerFormatterSinkProvider()

Не забудьте также изменить файл Web.Config

<channels>
      <channel ref="http" >
         <serverProviders>
             <formatter ref="soap" />
          </serverProviders>
          <clientProviders>
             <formatter ref="soap" />
           </clientProviders>
      </channel>
</channels>

Сервер недоступен из-за ошибки в IIS. Ошибка регистрируется в приложении в окне просмотра событий (Панель управления -> Администрирование -> Просмотр событий).

Моя ошибка произошла из-за того, что я изменил файл Machine.config, чтобы IIS не запускался под пользователем ASP_NET. Однако я не знал, что для каждой платформы есть файл. У IIS просто не было пользователя для запуска процесса aspnet_wp.exe, поскольку я отключил пользователя ASP_NET.

Крошечные ошибки, надеюсь, это поможет некоторым людям отладить свои .Net Remoting. Он отлично работает под .Net 4!

...