Ошибка: redirect_uri_mismatch Google API, как исправить? - PullRequest
1 голос
/ 20 февраля 2020

Я создал эту функцию HTTP триггера azure, которая содержит код (ниже) для автоматической загрузки видео на YouTube. Источник: (https://developers.google.com/youtube/v3/docs/videos/insert).

Я также создал Client_Id и Client_secret с помощью API консоли Google и сохранил эти данные в файле client_secrets. json. (Например, https://github.com/youtube/api-samples/blob/master/dotnet/client_secrets.json)

Я пытаюсь запустить функцию локально, вставив следующее: http://localhost: 7071 / api / Function1 в браузере, я получить следующую ошибку:

400, это ошибка. Ошибка: redirect_rui_mismatch URI перенаправления в запросе http://localhost58085/authorize/ не соответствует тем, которые разрешены для клиента OAuth. Чтобы обновить авторизованные URI перенаправления, посетите. http://consolse.Developers.google.com/apis/credentials.

Я не уверен, что я делаю неправильно, и я не знаю, какой URL я должен указать для "URI авторизованного перенаправления"

Код:

using System;
using System.IO;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using Google.Apis.Auth.OAuth2;
using Google.Apis.Upload;
using Google.Apis.YouTube.v3.Data;
using System.Reflection;
using Google.Apis.YouTube.v3;
using Google.Apis.Services;
using System.Threading;

namespace UploadVideo
{
    public static class Function1
    {
        [FunctionName("Function1")]
        public static async Task<IActionResult> Run(
            [HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
            ILogger log)
        {
            log.LogInformation("C# HTTP trigger function processed a request.");

            log.LogInformation("YouTube Data API: Upload Video");
            log.LogInformation("==============================");

            try
            {
                await Run();
            }
            catch (AggregateException ex)
            {
                foreach (var e in ex.InnerExceptions)
                {
                    log.LogInformation("Error: " + e.Message);
                }
            }

            return new OkObjectResult($"Video Processed..");

        }

        private static async Task Run()
        {
            UserCredential credential;
            using (var stream = new FileStream("client_secrets.json", FileMode.Open, FileAccess.Read))
            {
                credential = await GoogleWebAuthorizationBroker.AuthorizeAsync(
                    GoogleClientSecrets.Load(stream).Secrets,
                    // This OAuth 2.0 access scope allows an application to upload files to the
                    // authenticated user's YouTube channel, but doesn't allow other types of access.
                    new[] { YouTubeService.Scope.YoutubeUpload },
                    "user",
                    CancellationToken.None
                );
            }

            var youtubeService = new YouTubeService(new BaseClientService.Initializer()
            {
                HttpClientInitializer = credential,
                ApplicationName = Assembly.GetExecutingAssembly().GetName().Name
            });

            var video = new Video();
            video.Snippet = new VideoSnippet();
            video.Snippet.Title = "Default Video Title";
            video.Snippet.Description = "Default Video Description";
            video.Snippet.Tags = new string[] { "tag1", "tag2" };
            video.Snippet.CategoryId = "22"; // See https://developers.google.com/youtube/v3/docs/videoCategories/list
            video.Status = new VideoStatus();
            video.Status.PrivacyStatus = "unlisted"; // or "private" or "public"
            var filePath = @"C:\Users\Peter\Desktop\audio\Test.mp4"; // Replace with path to actual movie file.

            using (var fileStream = new FileStream(filePath, FileMode.Open))
            {
                var videosInsertRequest = youtubeService.Videos.Insert(video, "snippet,status", fileStream, "video/*");
                videosInsertRequest.ProgressChanged += videosInsertRequest_ProgressChanged;
                videosInsertRequest.ResponseReceived += videosInsertRequest_ResponseReceived;

                await videosInsertRequest.UploadAsync();
            }
        }

        private static void videosInsertRequest_ProgressChanged(Google.Apis.Upload.IUploadProgress progress)
        {
            switch (progress.Status)
            {
                case UploadStatus.Uploading:
                    Console.WriteLine("{0} bytes sent.", progress.BytesSent);
                    break;

                case UploadStatus.Failed:
                    Console.WriteLine("An error prevented the upload from completing.\n{0}", progress.Exception);
                    break;
            }
        }

        private static void videosInsertRequest_ResponseReceived(Video video)
        {
            Console.WriteLine("Video id '{0}' was successfully uploaded.", video.Id);
        }
    }
}

1 Ответ

1 голос
/ 20 февраля 2020

Принцип работы Oauth2 заключается в том, что пользователю предоставляется экран согласия

Хотите ли вы предоставить Peters потрясающее приложение для доступа к вашей учетной записи YouTube.

Если пользователь принимает это, после чего код авторизации возвращается в ваше приложение в точке перенаправления uri

http://localhost: 7071 / api / Function1

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

как добавить редирект uri

Под учетными данными найдите тот, который вы ищете

enter image description here

Щелкните значок карандаша

enter image description here

Примечание

Пожалуйста, помните, что GoogleWebAuthorizationBroker.AuthorizeAsyn c используется для установленных приложений, если вы попытаетесь открыть окно согласия браузера на сервере, если вы попытаетесь поставить это как функцию. вам нужно сделать что-то более похожее на это для веб-приложения Asp. net mvc Не могу утверждать, что много знаю о azure функциях, но если есть что-то вроде облачных функций, я не думаю, у них есть возможность отображать страницу веб-браузера для вашего пользователя. Я не думаю, что вы можете аутентифицировать пользователя с помощью Oauth2 с помощью функции azure.

...