Основная аутентификация прокси в 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);