Основная аутентификация прокси в C#: ошибка HTTP 407

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

вот мой код:

HttpWebRequest request = (HttpWebRequest)WebRequest.Create(URL);

IWebProxy proxy = WebRequest.GetSystemWebProxy();
CredentialCache cc = new CredentialCache();
NetworkCredential nc = new NetworkCredential();

nc.UserName = "userName";
nc.Password = "password";
nc.Domain = "mydomain";
cc.Add("http://20.154.23.100", 8888, "Basic", nc);
proxy.Credentials = cc;
//proxy.Credentials = System.Net.CredentialCache.DefaultCredentials;
request.Proxy = proxy;
request.Proxy.Credentials = cc;
request.Credentials = cc;
request.PreAuthenticate = true;

Я пробовал все возможное, но, похоже, мне чего-то не хватает. Это что-то вроде того, что я должен сделать две просьбы? Сначала без учетных данных, и как только я слышу от сервера о необходимости учетные данные, сделать тот же запрос с учетными данными?

5 ответов


этот метод может избежать необходимости жесткого кода или настройки учетных данных прокси-сервера, что может быть желательно.

поместите это в файл конфигурации приложения - вероятно, приложение.конфиг. Visual Studio переименует его в yourappname.исполняемый.config on build, и он окажется рядом с вашим исполняемым файлом. Если у вас нет файла конфигурации приложения, просто добавьте его, используя Добавить новый элемент в Visual Studio.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <system.net>
    <defaultProxy useDefaultCredentials="true" />
  </system.net>
</configuration>

Я получал очень похожую ситуацию, когда HttpWebRequest не собирал правильные данные прокси по умолчанию и установка UseDefaultCredentials также не работала. Форсирование настроек в коде, однако, работало с удовольствием:

IWebProxy proxy = myWebRequest.Proxy;
if (proxy != null) {
    string proxyuri = proxy.GetProxy(myWebRequest.RequestUri).ToString();
    myWebRequest.UseDefaultCredentials = true;
    myWebRequest.Proxy = new WebProxy(proxyuri, false);
    myWebRequest.Proxy.Credentials = System.Net.CredentialCache.DefaultCredentials;
}

и потому что это использует учетные данные по умолчанию он не должен запрашивать у пользователя их детали.


вот правильный способ использования прокси вместе с creds..

HttpWebRequest request = (HttpWebRequest)WebRequest.Create(URL);

IWebProxy proxy = request.Proxy;                    
if (proxy != null)
{
    Console.WriteLine("Proxy: {0}", proxy.GetProxy(request.RequestUri));
}
else
{
    Console.WriteLine("Proxy is null; no proxy will be used");
}

WebProxy myProxy = new WebProxy();
Uri newUri = new Uri("http://20.154.23.100:8888");
// Associate the newUri object to 'myProxy' object so that new myProxy settings can be set.
myProxy.Address = newUri;
// Create a NetworkCredential object and associate it with the 
// Proxy property of request object.
myProxy.Credentials = new NetworkCredential("userName", "password");
request.Proxy = myProxy;

спасибо всем за помощь... :)


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

недавно я обновил проект до .NET 4 с 3.5, и код только начал работать с использованием учетных данных по умолчанию для прокси, без жесткого кодирования учетных данных и т. д.

request.Proxy.Credentials = CredentialCache.DefaultCredentials;

попробуй такое

        var YourURL = "http://yourUrl/";

         HttpClientHandler handler = new HttpClientHandler() 
         { 
             Proxy = new WebProxy("http://127.0.0.1:8888"), 
             UseProxy = true, 
         }; 

         Console.WriteLine(YourURL); 

         HttpClient client = new HttpClient(handler);