Подтвердить что ты не робот

Формат запроса непризнан для URL, неожиданно заканчивающегося на '/Convert', происходит через 1-2 дня

Я вызываю веб-сервис, используя вызов Microsoft.XMLHTTP:

var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
xmlhttp.open("POST", "/xxx/Converter.asmx/Convert", false);
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlhttp.send("conversionFolder=" + escape(conversionFolder));
if (xmlhttp.status == 200) {
  xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
  xmlDoc.async = "false";
  xmlDoc.loadXML(xmlhttp.responseText);
  ... more stuff ...
  return str;
}
else {
  alert(xmlhttp.statusCode + " - " + xmlhttp.statusText);
}

Все работает отлично, когда я не могу добавить протокол HttpPost в локальный web.config:

<?xml version="1.0"?>
<configuration>
  <appSettings/>
  <connectionStrings/>
  <system.web>
    <webServices>
      <protocols>
        <add name="HttpPost"/>
      </protocols>
    </webServices>
    <compilation debug="false"></compilation>
  </system.web>
  <system.codedom>
  </system.codedom>
  <!--
    The system.webServer section is required for running ASP.NET AJAX under Internet
    Information Services 7.0.  It is not necessary for previous version of IIS.
  -->
  <system.webServer>
  </system.webServer>
</configuration>

Но на одном сервере производства он терпит неудачу после запуска в течение 1-2 дней. Он отлично работает после того, как процесс asp.net был переработан. Он работает в течение 1-2 дней, а затем он терпит неудачу:

Exception information:
Exception type: InvalidOperationException
Exception message: Request format is unrecognized for URL unexpectedly ending in '/Convert'.

Request information:
Request URL: https://xxx/xxx/converter.asmx/Convert
Request path: /xxx/converter.asmx/Convert
User host address: 195.50.35.4
User: extranet\kbk
Is authenticated: True
Authentication Type:
Thread account name: NT AUTHORITY\NETWORK SERVICE

Thread information:
Thread ID: 14
Thread account name: NT AUTHORITY\NETWORK SERVICE
Is impersonating: False
Stack trace: at System.Web.Services.Protocols.WebServiceHandlerFactory.CoreGetHandler(Type type, HttpContext context, HttpRequest request, HttpResponse response)
at System.Web.Services.Protocols.WebServiceHandlerFactory.GetHandler(HttpContext context, String verb, String url, String filePath)
at System.Web.Script.Services.ScriptHandlerFactory.GetHandler(HttpContext context, String requestType, String url, String pathTranslated)
at System.Web.HttpApplication.MaterializeHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute()
at System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously)

Почему он ждет 2 дня перед сбоем? И что я могу сделать, чтобы предотвратить его провал? Связано ли это с тем, что этот сервер работает в режиме HTTPS?

4b9b3361

Ответ 1

Какова структура Dot Net? IIS 6 или 7?
Вы пробовали добавить <add name="HttpGet"/> в разделе протоколов. Кажется, некоторые люди справились с этой проблемой с этим исправлением. (но не для всех)
ссылка 1
ссылка 2
Также проверьте, где вы размещаете свой сайт. Это на уровне корня вашего веб-сервера или виртуальной папки. Иногда это может быть наследование некоторых значений конфигурации с сайтов родительского уровня или файла machine.config.

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

Ответ 2

Кажется, есть исправление, доступное для повторного использования пула приложений, устраняет проблему в течение нескольких дней: http://support.microsoft.com/kb/2783777/en-us

Ответ 3

Похоже, что протоколы отключены по умолчанию. Аналогичный вопрос уже задан в Stackoverflow. Проверьте ссылку и соответствующую question