Не удалось успешно запустить функцию Azure, которая содержит код для загрузки видео на YouTube - PullRequest
1 голос
/ 19 февраля 2020

Я в основном создаю функцию HTTP Trigger Azure, в которой есть код для загрузки видео на YouTube с помощью API YouTube. Код был в значительной степени предоставлен документами YouTubeAPI: https://developers.google.com/youtube/v3/docs/videos/insert. Я немного переформатировал код, чтобы он соответствовал функции Azure.

Однако, когда я пытаюсь запустить функцию локально в Visual Studio, я получаю сообщение об ошибке 500:

Выполнено «Function1» (Failed, Id = 84400f0 c -b6e4-4c78-bf55-30c4527a8b5f) System.Private.CoreLib: Исключительная ситуация при выполнении функции: Function1. System.Private.CoreLib: не удалось найти файл 'C: \ Users \ Peter \ Desktop \ TestDemo \ UploadVideo \ UploadVideo \ bin \ Debug \ netcoreapp2.1 \ client_secrets. json'.

Я не уверен, как исправить эту ошибку и заставить функцию работать без ошибок. Есть ли что-то, что нужно добавить / изменить в коде (ниже), чтобы исправить эту проблему?

Моя цель: моя конечная цель - запускать эту функцию azure всякий раз, когда в Azure Blob Storage добавляется новое видео.

Код

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);
        }
    }
}

Ответы [ 2 ]

0 голосов
/ 21 февраля 2020

Во-первых, из ваших требований:

Моя цель: моя конечная цель - запускать эту функцию azure всякий раз, когда в Azure Blob Storage добавляется новое видео.

Для достижения цели необходимо использовать Azure триггер BLOB-объекта.

И из-за вашей ошибки:

Выполнено 'Function1' (Failed, Id = 84400f0 c -b6e4-4c78-bf55-30c4527a8b5f) System.Private.CoreLib: Исключительная ситуация при выполнении функции: Function1. System.Private.CoreLib: не удалось найти файл 'C: \ Users \ Peter \ Desktop \ TestDemo \ UploadVideo \ UploadVideo \ bin \ Debug \ netcoreapp2.1 \ client_secrets. json'.

Я думаю, вы не изменили свойства файла json на «Копировать, если новее» после его создания. Если вы не измените это свойство, вы столкнетесь с этой ошибкой. Таким образом, он находится в той же папке с вашим кодом, но не в той же папке, где находится файл DLL.

0 голосов
/ 19 февраля 2020

Не удалось найти файл 'C: \ Users \ Peter \ Desktop \ TestDemo \ UploadVideo \ UploadVideo \ bin \ Debug \ netcoreapp2.1 \ client_secrets. json'.

Он ищет "client_secrets. json", он должен находиться в одном каталоге с вашим кодом. как вы не сказали, чтобы он смотрел куда-либо еще *

using (var stream = new FileStream("client_secrets.json", FileMode.Open, FileAccess.Read))
        {

Примечание

GoogleWebAuthorizationBroker.AuthorizeAsyn c предназначен только для использования с установленными приложениями. Он собирается открывать веб-браузер на сервере. и предложите пользователю подтвердить подлинность кода.

исправьте меня, если я не прав, но функции azure не имеют конечной точки пользовательского интерфейса, где вы можете запросить пользователя для проверки подлинности. Это означает, что вы можете использовать только учетную запись службы, а API YouTube не поддерживает учетные записи службы.

...