401 Несанкционированный возврат в EndGetResponse. Журнал ошибок Apache: не удается сгенерировать контекст

#c# #authorization #apache2 #fiddler #webrequest

#c# #авторизация #apache2 #скрипач #веб-запрос

Вопрос:

У меня есть сервер с запущенным Apache. Теперь я хочу иметь возможность читать содержимое папки там, и для этого эта папка настроена в Apache httpd.conf примерно так:

 Alias /folder "E:/Folder"

<Directory "E:/Folder">
  AuthName "Public Folder"
  AuthType SSPI
  SSPIAuth On
  SSPIAuthoritative On
  SSPIDomain DOMAIN
  SSPIOfferBasic On
  SSPIOfferSSPI On
  SSPIBasicPreferred Off
  SSPIOmitDomain On
  SSPIUsernameCase lower
  require group "DOMAINDomain Users"
</Directory>
  

Теперь, когда я использую браузер, я уже могу получить доступ к этой информации с помощью URL http://ServerName/Folder /

Так что это уже работает просто отлично. Но теперь я пытаюсь получить эти данные папки для моего приложения на C #. Я использую DefaultNetworkCredentials, и мой код выглядит примерно так:

 public void CheckFolder()
{
    WebRequest request = HttpWebRequest.Create(_uri);
    request.Credentials = CredentialCache.DefaultNetworkCredentials;
    request.BeginGetResponse(new AsyncCallback(HandleGetAvailableUpdates), request);
}

void HandleGetAvailableUpdates(IAsyncResult state)
{
    try
    {
        if (state.IsCompleted)
        {
            WebRequest req = state.AsyncState as WebRequest;
            WebResponse response = req.EndGetResponse(state);
            Stream wStream = null;
            wStream = response.GetResponseStream();
            byte[] data = new byte[response.ContentLength];

            etc.
            .
            .
            .

        }
        catch (WebException ex)
        {
            Console.WriteLine(ex.ToString());
        }
    }
}
  

req.EndGetResponse(состояние) теперь выдает исключение WebException:

 The remote server returned an error: (401) Unauthorized.
  

Возвращаясь на сторону сервера, я просматриваю Apache error.log и там нахожу:

 (OS 87)The parameter is incorrect.  : authentication failure for "/folder": user unknown, reason: cannot generate context
  

Эта функция программы уже хорошо работала около двух месяцев назад. C #-код вообще не изменился, но я не знаю, было ли что-то сделано с сервером или конфигурацией Apache. Я также пытался ввести свои учетные данные (имя пользователя и pw, те же, которые я использую при доступе через веб-браузер) вручную в C #-коде, а не использовать DefaultNetworkCredentials, но безрезультатно. Итак, наконец, мой вопрос: есть ли что-то, что я забыл? Существуют ли какие-либо другие настройки на сервере, которые необходимо выполнить, чтобы заставить его работать?

Ответ №1:

Самый простой способ узнать: User Fiddler, или Live Http Headers, или любой другой анализатор пакетов HTTP, чтобы увидеть, какие заголовки / параметры post отправляются браузером, а затем дублировать их все программно.

Комментарии:

1. Вау, теперь это становится интересным! Я установил Fiddler (на стороне клиента) и сравнил пакеты из браузера и моего приложения. Я ничего не смог найти, а затем понял, что веб-запрос из моего приложения внезапно сработал нормально. Я снова отключил анализатор, «401 несанкционированный». Я пробовал это четыре раза, и это всегда одно и то же. Когда скрипач записывает, я не получаю ошибку. Так что это похоже на «принцип неопределенности Гейзенберга»… Есть предложения?