我試圖從谷歌磁盤下載文件。 驗證類:谷歌驅動器API代理異常407
internal static class Perm_AppData
{
private static string[] scopes = { DriveService.Scope.DriveFile };
private static DriveService service = Autorization();
internal static DriveService Service { get { return service; } }
private static DriveService Autorization()
{
UserCredential credential;
using (var stream = GetCliSecStream())
{
credential = GoogleWebAuthorizationBroker.AuthorizeAsync(
GoogleClientSecrets.Load(stream).Secrets,
scopes,
"user",
CancellationToken.None,
new FileDataStore(auth, true)).Result;
}
return new DriveService(new BaseClientService.Initializer()
{
HttpClientInitializer = credential,
ApplicationName = applicationName
});
}
private static Stream GetCliSecStream()
{
var stream = new MemoryStream();
var writer = new StreamWriter(stream);
writer.Write(uSec);
writer.Flush();
stream.Position = 0;
return stream;
}
}
在那之後,我選擇了一個帳戶,並確認後,申請的權利。下一步是下載文件
internal static MemoryStream DownloadFile(string fileId = null, string fileName = null)
{
using (new Watcher($"Download {fileName} {fileId}"))
{
GetRequest request = null;
if (fileId != null)
{
request = service.Files.Get(fileId);
}
else
{
if (fileName != null)
{
request = service.Files.Get(ViewDrive(SearchParameter.name, new string[] { fileName }).First().Id);
}
else
{
throw new Exception("You need at least one not null parameter to download");
}
}
request.Fields = "id, name";
var fileMemoryStream = new MemoryStream();
request.Download(fileMemoryStream);
return fileMemoryStream;
}
}
下載文件拋出異常的請求(System.Net.WebException:遠程服務器返回錯誤:(407)需要代理認證):
Error: System.TypeInitializationException: Инициализатор типа "Updater.UnDloadAP I" выдал исключение. ---> System.TypeInitializationException: Инициализатор типа "Updater.Perm_AppData" выдал исключение. ---> System.AggregateException: Произо шла одна или несколько ошибок. ---> System.Net.Http.HttpRequestException: Произо шла ошибка при отправке запроса. ---> System.Net.WebException: Удаленный сервер возвратил ошибку: (407) Требуется аутентификация посредника. в System.Net.HttpWebRequest.EndGetRequestStream(IAsyncResult asyncResult, Tra nsportContext& context) в System.Net.Http.HttpClientHandler.GetRequestStreamCallback(IAsyncResult ar)
--- Конец трассировки внутреннего стека исключений --- в Google.Apis.Http.ConfigurableMessageHandler.d__55.MoveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.Requests.TokenRequestExtenstions.d__0 .MoveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.Flows.AuthorizationCodeFlow.d__35. MoveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.Flows.AuthorizationCodeFlow.d__30.MoveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.AuthorizationCodeInstalledApp.d__8. MoveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.GoogleWebAuthorizationBroker.d__4.M oveNext() --- Конец трассировка стека из предыдущего расположения, где возникло исключение --- в System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) в System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNoti fication(Task task) в Google.Apis.Auth.OAuth2.GoogleWebAuthorizationBroker.d__1.M oveNext() --- Конец трассировки внутреннего стека исключений ---
в System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledE xceptions) в System.Threading.Tasks.Task1.GetResultCore(Boolean waitCompletionNotificat ion) в System.Threading.Tasks.Task
1.get_Result() в Updater.Perm_AppData.Autorization() в C:\Users\User\Documents\Visual Studio Projects\SMNote\Updater\Classes\API\Perm_AppData.cs:строка 27
我需要這樣的東西:
WebRequest.DefaultWebProxy.Credentials = CredentialCache.DefaultNetworkCredentials;
我沒有得到一個錯誤,如果我連接到Internet不使用代理
更新的Post#1: 下面的代碼通常是通過代理服務器通過
var request = (HttpWebRequest)WebRequest.Create(link);
request.Credentials = CredentialCache.DefaultCredentials;
request.Proxy.Credentials = CredentialCache.DefaultCredentials;
因此,我認爲,你需要一個代理莫名其妙手動添加到了谷歌的要求驅動
更新的Post#2:
下面的代碼正常通過代理
internal static void DoIt()
{
try
{
var t = DownloadPageAsync();
Console.WriteLine("Downloading page...");
Console.WriteLine(t.Result);
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
}
private static async Task<string> DownloadPageAsync()
{
var proxy = WebRequest.DefaultWebProxy;
proxy.Credentials = CredentialCache.DefaultCredentials;
var httpClientHandler = new HttpClientHandler()
{
Proxy = proxy
};
using (HttpClient client = new HttpClient(httpClientHandler))
{
using (HttpResponseMessage response = await client.GetAsync("https://mail.ru"))
{
using (HttpContent content = response.Content)
{
string result = await content.ReadAsStringAsync();
return result.Substring(0, 50);
}
}
}
}
「我需要類似的東西」 - 所以如果你這樣做會發生什麼?我希望* WebRequest.DefaultWebProxy被默認使用。 –
已更新#1 –
您仍然沒有說過如果您設置了「WebRequest.DefaultWebProxy」及其憑據,會發生什麼情況。這就是我希望我們的代碼隱式使用,通過'HttpClientHandler' –