Oauth 2-如何使用刷新令牌

时间:2016-06-08 06:46:56

标签: c# .net google-api google-oauth google-api-dotnet-client

我使用Google Api更改用户日历 - 与客户端应用中的日历同步。我找不到关于如何以及何时使用刷新令牌的任何教程。下面是我的测试应用程序来读取/写入谷歌日历。如何检查访问令牌是否已过期,我应该在哪里以及如何刷新令牌?

using Google.Apis.Auth.OAuth2;
using Google.Apis.Calendar.v3;
using Google.Apis.Calendar.v3.Data;
using Google.Apis.Services;
using Google.Apis.Util.Store;
using Google.Apis;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;

namespace CalendarQuickstart
{
    class Program
    {
        // If modifying these scopes, delete your previously saved credentials
        // at ~/.credentials/calendar-dotnet-quickstart.json
        static string[] Scopes = { CalendarService.Scope.Calendar };
        static string ApplicationName = "test";

        static void Main(string[] args)
        {
            UserCredential credential;

            using (var stream = new FileStream("NewFolder1/client_secret.json", FileMode.Open, FileAccess.Read))
            {
                string credPath = System.Environment.GetFolderPath(
                    System.Environment.SpecialFolder.Personal);
                credPath = Path.Combine(credPath, ".credentials/test.json");

                credential = GoogleWebAuthorizationBroker.AuthorizeAsync(
                    GoogleClientSecrets.Load(stream).Secrets,
                    Scopes,
                    "user1234",
                    CancellationToken.None,
                    new FileDataStore(credPath, true)).Result;

            }

            // Create Google Calendar API service.
            var service = new CalendarService(new BaseClientService.Initializer()
            {
                HttpClientInitializer = credential,
                ApplicationName = ApplicationName,
            });


            // Define parameters of request.
            EventsResource.ListRequest request = service.Events.List("primary");
            request.TimeMin = DateTime.Now;
            request.ShowDeleted = false;
            request.SingleEvents = true;
            request.MaxResults = 10;
            request.OrderBy = EventsResource.ListRequest.OrderByEnum.StartTime;

            // List events.
            Events events = request.Execute();
            Console.WriteLine("Upcoming events:");
            if (events.Items != null && events.Items.Count > 0)
            {
                foreach (var eventItem in events.Items)
                {
                    string when = eventItem.Start.DateTime.ToString();
                    if (String.IsNullOrEmpty(when))
                    {
                        when = eventItem.Start.Date;
                    }
                    Console.WriteLine("{0} ({1})", eventItem.Summary, when);
                }
            }
            else
            {
                Console.WriteLine("No upcoming events found.");
            }

            /////////////
            Event newEvent = new Event()
            {
                Summary = "Google I/O 2015",
                Description = "A chance to hear more about Google's developer products.",

                Start = new EventDateTime()
                {
                    DateTime = DateTime.Now,
                },
                End = new EventDateTime()
                {
                    DateTime = DateTime.Now.AddHours(1),
                },
            };

            String calendarId = "primary";
            EventsResource.InsertRequest requestInsertEvent = service.Events.Insert(newEvent, calendarId);
            Event createdEvent = requestInsertEvent.Execute();
            Console.WriteLine("Event created: {0}", createdEvent.Id);
            /////////////

            Console.Read();

        }
    }
}

2 个答案:

答案 0 :(得分:2)

您无需测试访问令牌是否已过期,客户端库将为您处理该问题。

但是,如果由于某种原因你真的想要,你可以发送到

https://www.googleapis.com/oauth2/v3/tokeninfo?access_token=1/fFBGRNJru1FQd44AzqT3Zg

如果无效,将返回错误。

答案 1 :(得分:0)

DaImTo是对的,您无需担心客户端库会为您做到这一点。

这里有一个教程和更多细节: https://developers.google.com/api-client-library/dotnet/guide/aaa_oauth#acquiring--client-ids-and-secrets 包括提及以下内容的User Credential部分:

UserCredential和AuthorizationCodeFlow自动“刷新”令牌,这意味着获取新的访问令牌。这是使用长期刷新令牌完成的,如果在授权代码流期间使用access_type = offline参数,则会与访问令牌一起使用。