Используйте Google Analytics API для отображения информации в C#

Я весь день искал хорошее решение, но Google развивается так быстро, что не может найти что-то работающее. Что я хочу сделать, так это то, что у меня есть веб-приложение, в котором есть раздел администратора, в который необходимо войти, чтобы увидеть информацию. В этом разделе я хочу показать некоторые данные из GA, такие как просмотры страниц для некоторых конкретных URL. Так как я показываю не пользовательскую информацию, а пользователя google analytics, я хочу подключить передаваемую информацию (имя пользователя / пароль или APIKey), но не могу узнать, как это сделать. Все примеры, которые я нашел, используют OAuth2 (ведьма, если я понимаю, попросит посетителя войти в систему с помощью Google).

Что я нашел до сих пор:

Может быть, я просто устала и что завтра будет легко найти решение, но сейчас мне нужна помощь!

Спасибо

7 ответов

Решение

Я много занимался поиском и, наконец, либо просматривая код из разных мест, а затем оборачивая вокруг него свой собственный интерфейс, я придумал следующее решение. Не уверен, что люди вставят сюда весь свой код, но я думаю, почему бы не сэкономить время остальных:)

Предварительные реквизиты, вам нужно будет установить Google.GData.Client и google.gdata.analytics package/dll.

Это основной класс, который делает работу.

namespace Utilities.Google
{
    public class Analytics
    {
        private readonly String ClientUserName;
        private readonly String ClientPassword;
        private readonly String TableID;
        private AnalyticsService analyticsService;

        public Analytics(string user, string password, string table)
        {
            this.ClientUserName = user;
            this.ClientPassword = password;
            this.TableID = table;

            // Configure GA API.
            analyticsService = new AnalyticsService("gaExportAPI_acctSample_v2.0");
            // Client Login Authorization.
            analyticsService.setUserCredentials(ClientUserName, ClientPassword);
        }

        /// <summary>
        /// Get the page views for a particular page path
        /// </summary>
        /// <param name="pagePath"></param>
        /// <param name="startDate"></param>
        /// <param name="endDate"></param>
        /// <param name="isPathAbsolute">make this false if the pagePath is a regular expression</param>
        /// <returns></returns>
        public int GetPageViewsForPagePath(string pagePath, DateTime startDate, DateTime endDate, bool isPathAbsolute = true)
        {
            int output = 0;

            // GA Data Feed query uri.
            String baseUrl = "https://www.google.com/analytics/feeds/data";

            DataQuery query = new DataQuery(baseUrl);
            query.Ids = TableID;
            //query.Dimensions = "ga:source,ga:medium";
            query.Metrics = "ga:pageviews";
            //query.Segment = "gaid::-11";
            var filterPrefix = isPathAbsolute ? "ga:pagepath==" : "ga:pagepath=~";
            query.Filters = filterPrefix + pagePath;
            //query.Sort = "-ga:visits";
            //query.NumberToRetrieve = 5;
            query.GAStartDate = startDate.ToString("yyyy-MM-dd", CultureInfo.InvariantCulture);
            query.GAEndDate = endDate.ToString("yyyy-MM-dd", CultureInfo.InvariantCulture);
            Uri url = query.Uri;
            DataFeed feed = analyticsService.Query(query);
            output = Int32.Parse(feed.Aggregates.Metrics[0].Value);

            return output;
        }

        public Dictionary<string, int> PageViewCounts(string pagePathRegEx, DateTime startDate, DateTime endDate)
        {
            // GA Data Feed query uri.
            String baseUrl = "https://www.google.com/analytics/feeds/data";

            DataQuery query = new DataQuery(baseUrl);
            query.Ids = TableID;
            query.Dimensions = "ga:pagePath";
            query.Metrics = "ga:pageviews";
            //query.Segment = "gaid::-11";
            var filterPrefix = "ga:pagepath=~";
            query.Filters = filterPrefix + pagePathRegEx;
            //query.Sort = "-ga:visits";
            //query.NumberToRetrieve = 5;
            query.GAStartDate = startDate.ToString("yyyy-MM-dd", CultureInfo.InvariantCulture);
            query.GAEndDate = endDate.ToString("yyyy-MM-dd", CultureInfo.InvariantCulture);
            Uri url = query.Uri;
            DataFeed feed = analyticsService.Query(query);

            var returnDictionary = new Dictionary<string, int>();
            foreach (var entry in feed.Entries)
                returnDictionary.Add(((DataEntry)entry).Dimensions[0].Value, Int32.Parse(((DataEntry)entry).Metrics[0].Value));

            return returnDictionary;
        }
    }
}

И это интерфейс и реализация, которую я использую, чтобы обернуть это.

namespace Utilities
{
    public interface IPageViewCounter
    {
        int GetPageViewCount(string relativeUrl, DateTime startDate, DateTime endDate, bool isPathAbsolute = true);
        Dictionary<string, int> PageViewCounts(string pagePathRegEx, DateTime startDate, DateTime endDate);
    }

    public class GooglePageViewCounter : IPageViewCounter
    {
        private string GoogleUserName
        {
            get
            {
                return ConfigurationManager.AppSettings["googleUserName"];
            }
        }

        private string GooglePassword
        {
            get
            {
                return ConfigurationManager.AppSettings["googlePassword"];
            }
        }

        private string GoogleAnalyticsTableName
        {
            get
            {
                return ConfigurationManager.AppSettings["googleAnalyticsTableName"];
            }
        }

        private Analytics analytics;

        public GooglePageViewCounter()
        {
            analytics = new Analytics(GoogleUserName, GooglePassword, GoogleAnalyticsTableName);
        }

        #region IPageViewCounter Members

        public int GetPageViewCount(string relativeUrl, DateTime startDate, DateTime endDate, bool isPathAbsolute = true)
        {
            int output = 0;
            try
            {
                output = analytics.GetPageViewsForPagePath(relativeUrl, startDate, endDate, isPathAbsolute);
            }
            catch (Exception ex)
            {
                Logger.Error(ex);
            }

            return output;
        }

        public Dictionary<string, int> PageViewCounts(string pagePathRegEx, DateTime startDate, DateTime endDate)
        {
            var input = analytics.PageViewCounts(pagePathRegEx, startDate, endDate);
            var output = new Dictionary<string, int>();

            foreach (var item in input)
            {
                if (item.Key.Contains('&'))
                {
                    string[] key = item.Key.Split(new char[] { '?', '&' });
                    string newKey = key[0] + "?" + key.FirstOrDefault(k => k.StartsWith("p="));

                    if (output.ContainsKey(newKey))
                        output[newKey] += item.Value;
                    else
                        output[newKey] = item.Value;
                }
                else
                    output.Add(item.Key, item.Value);
            }
            return output;
        }

        #endregion
    }
}

А теперь остальное очевидно: вам нужно будет добавить значения web.config в конфигурацию вашего приложения или webconfig и вызвать IPageViewCounter.GetPageViewCount.

Это требует немного настройки на стороне Google, но на самом деле это довольно просто. Я перечислю шаг за шагом.

Сначала вам нужно будет создать приложение в облачной консоли Google и включить Google Analytics API.

  • Перейдите на http://code.google.com/apis/console.
  • Выберите раскрывающийся список и создайте проект, если у вас его еще нет
  • Как только проект создан, нажмите на сервис
  • Отсюда включите Google Analytics API

Теперь, когда API-интерфейс Google Analytics включен, следующим шагом будет включение учетной записи службы для доступа к нужным профилям / сайтам аналитики. Учетная запись службы позволит вам войти в систему, не запрашивая у пользователя учетные данные.

  • Перейдите на http://code.google.com/apis/console и выберите созданный вами проект в раскрывающемся списке.
  • Затем перейдите в раздел "Доступ к API" и нажмите кнопку "Создать другой идентификатор клиента".
  • В окне "Создать идентификатор клиента" выберите учетную запись службы и нажмите "Создать идентификатор клиента".
  • Загрузите открытый ключ для этой учетной записи, если он не запускает загрузку автоматически. Это понадобится вам позже, когда вы будете вводить код для авторизации.
  • Перед выходом скопируйте сервисные учетные записи автоматически сгенерированного адреса электронной почты, так как он понадобится вам на следующем шаге. Электронная почта клиента выглядит как @ developer.gserviceaccount.com

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

  • Войдите в Google Analytics.
  • После входа в систему нажмите на кнопку "Администратор" в нижней части экрана.
  • В разделе "Администратор" щелкните раскрывающуюся учетную запись и выберите учетную запись / сайт, к которому вы хотите иметь доступ к учетной записи службы, затем нажмите "Управление пользователями" в разделе учетной записи.
  • Введите адрес электронной почты, который был создан для вашей учетной записи службы, и дайте ему разрешение на чтение и анализ.
  • Повторите эти шаги для любой другой учетной записи / сайта, к которому вы хотите, чтобы ваш сервис имел доступ.

Теперь, когда настройка учетной записи службы завершена для доступа к Google Analytics через API, мы можем начать кодировать.

Получить этот пакет от NuGet:

Клиентская библиотека Google.Apis.Analytics.v3

Добавьте эти использования:

using Google.Apis.Analytics.v3;
using Google.Apis.Analytics.v3.Data;
using Google.Apis.Services;
using System.Security.Cryptography.X509Certificates;
using Google.Apis.Auth.OAuth2;
using System.Collections.Generic; 
using System.Linq;

Некоторые вещи, на которые стоит обратить внимание.

  • keyPath путь к файлу ключа, который вы скачали с расширением файла.p12.
  • accountEmailAddress это API-адрес электронной почты, который мы получили ранее.
  • Сфера является Enum в Google.Apis.Analytics.v3.AnalyticService класс, который диктует URL для использования для авторизации (например: AnalyticsService.Scope.AnalyticsReadonly).
  • Имя приложения - это имя по вашему выбору, которое сообщает API Google, что к нему обращается (иначе: это может быть то, что вы выберете).

Тогда код для выполнения некоторых основных вызовов выглядит следующим образом.

public class GoogleAnalyticsAPI
{
    public AnalyticsService Service { get; set; }

    public GoogleAnalyticsAPI(string keyPath, string accountEmailAddress)
    {
        var certificate = new X509Certificate2(keyPath, "notasecret", X509KeyStorageFlags.Exportable);

        var credentials = new ServiceAccountCredential(
           new ServiceAccountCredential.Initializer(accountEmailAddress)
           {
               Scopes = new[] { AnalyticsService.Scope.AnalyticsReadonly }
           }.FromCertificate(certificate));

        Service = new AnalyticsService(new BaseClientService.Initializer()
            {
                HttpClientInitializer = credentials,
                ApplicationName = "WorthlessVariable"
            });
    }

    public AnalyticDataPoint GetAnalyticsData(string profileId, string[] dimensions, string[] metrics, DateTime startDate, DateTime endDate)
    {
        AnalyticDataPoint data = new AnalyticDataPoint();
        if (!profileId.Contains("ga:"))
            profileId = string.Format("ga:{0}", profileId);

        //Make initial call to service.
        //Then check if a next link exists in the response,
        //if so parse and call again using start index param.
        GaData response = null;
        do
        {
            int startIndex = 1;
            if (response != null && !string.IsNullOrEmpty(response.NextLink))
            {
                Uri uri = new Uri(response.NextLink);
                var paramerters = uri.Query.Split('&');
                string s = paramerters.First(i => i.Contains("start-index")).Split('=')[1];
                startIndex = int.Parse(s);
            }

            var request = BuildAnalyticRequest(profileId, dimensions, metrics, startDate, endDate, startIndex);
            response = request.Execute();
            data.ColumnHeaders = response.ColumnHeaders;
            data.Rows.AddRange(response.Rows);

        } while (!string.IsNullOrEmpty(response.NextLink));

        return data;
    }

    private DataResource.GaResource.GetRequest BuildAnalyticRequest(string profileId, string[] dimensions, string[] metrics,
                                                                        DateTime startDate, DateTime endDate, int startIndex)
    {
        DataResource.GaResource.GetRequest request = Service.Data.Ga.Get(profileId, startDate.ToString("yyyy-MM-dd"),
                                                                            endDate.ToString("yyyy-MM-dd"), string.Join(",", metrics));
        request.Dimensions = string.Join(",", dimensions);
        request.StartIndex = startIndex;
        return request;
    }

    public IList<Profile> GetAvailableProfiles()
    {
        var response = Service.Management.Profiles.List("~all", "~all").Execute();
        return response.Items;
    }

    public class AnalyticDataPoint
    {
        public AnalyticDataPoint()
        {
            Rows = new List<IList<string>>();
        }

        public IList<GaData.ColumnHeadersData> ColumnHeaders { get; set; }
        public List<IList<string>> Rows { get; set; }
    }
}

Другие ссылки, которые окажутся полезными:

Analytic API Explorer - API запросов из Интернета

Analytic API Explorer версии 2 - API запросов из Интернета

Справочник по измерениям и метрикам

Надеюсь, это поможет кому-то, пытающемуся сделать это в будущем.

Этот ответ предназначен для тех из вас, кто хочет получить доступ к своей учетной записи Google Analytics и хочет использовать новый API отчетов Analytics v4.

Недавно я написал сообщение в блоге о том, как получать данные Google Analytics с помощью C#. Читайте там для всех деталей.

Сначала вам нужно выбрать между подключением с OAuth2 или учетной записью службы. Я предполагаю, что у вас есть учетная запись Google Analytics, поэтому вам нужно создать "ключ учетной записи службы" на странице учетных данных API Google.

Как только вы это создадите, загрузите файл JSON и поместите его в свой проект (я поместил свой в свой App_Data папка).

Затем установите пакет Nuget для Google.Apis.AnalyticsReporting.v4. Также установите Newtonsoft's Json.NET.

Включите этот класс где-нибудь в свой проект:

public class PersonalServiceAccountCred
{
    public string type { get; set; }
    public string project_id { get; set; }
    public string private_key_id { get; set; }
    public string private_key { get; set; }
    public string client_email { get; set; }
    public string client_id { get; set; }
    public string auth_uri { get; set; }
    public string token_uri { get; set; }
    public string auth_provider_x509_cert_url { get; set; }
    public string client_x509_cert_url { get; set; }
}

И вот чего вы ждали: полный пример!

string keyFilePath = Server.MapPath("~/App_Data/Your-API-Key-Filename.json");
string json = System.IO.File.ReadAllText(keyFilePath);

var cr = JsonConvert.DeserializeObject(json);

var xCred = new ServiceAccountCredential(new ServiceAccountCredential.Initializer(cr.client_email)
{
    Scopes = new[] {
        AnalyticsReportingService.Scope.Analytics
    }
}.FromPrivateKey(cr.private_key));

using (var svc = new AnalyticsReportingService(
    new BaseClientService.Initializer
    {
        HttpClientInitializer = xCred,
        ApplicationName = "[Your Application Name]"
    })
)
{
    // Create the DateRange object.
    DateRange dateRange = new DateRange() { StartDate = "2017-05-01", EndDate = "2017-05-31" };

    // Create the Metrics object.
    Metric sessions = new Metric { Expression = "ga:sessions", Alias = "Sessions" };

    //Create the Dimensions object.
    Dimension browser = new Dimension { Name = "ga:browser" };

    // Create the ReportRequest object.
    ReportRequest reportRequest = new ReportRequest
    {
        ViewId = "[A ViewId in your account]",
        DateRanges = new List() { dateRange },
        Dimensions = new List() { browser },
        Metrics = new List() { sessions }
    };

    List requests = new List();
    requests.Add(reportRequest);

    // Create the GetReportsRequest object.
    GetReportsRequest getReport = new GetReportsRequest() { ReportRequests = requests };

    // Call the batchGet method.
    GetReportsResponse response = svc.Reports.BatchGet(getReport).Execute();
}

Мы начнем с десериализации информации ключа учетной записи службы из файла JSON и преобразуем ее в PersonalServiceAccountCred объект. Затем мы создаем ServiceAccountCredential и подключиться к Google через AnalyticsReportingService, Используя этот сервис, мы подготавливаем некоторые базовые фильтры для передачи в API и отправки запроса.

Вероятно, лучше установить точку останова на линии, где response объявлена ​​переменная, нажмите F10 один раз, затем наведите курсор на переменную, чтобы увидеть, какие данные доступны для использования в ответе.

Я надеялся просто добавить комментарий к ответу для v3 Beta, но точки повторения мешают этому. Однако я подумал, что для других было бы неплохо иметь эту информацию, поэтому вот она:

using Google.Apis.Authentication.OAuth2;
using Google.Apis.Authentication.OAuth2.DotNetOpenAuth;
using System.Security.Cryptography.X509Certificates;
using Google.Apis.Services;

Эти пространства имен используются во всем коде в этом посте. Я всегда хотел бы, чтобы люди публиковали пространства имен чаще, я, кажется, трачу много времени на их поиск. Я надеюсь, что это спасет некоторых людей от нескольких минут работы.

Я настроил что-то похожее на ответ в пакете nuGet. Он выполняет следующие действия: - подключается к "служебной учетной записи", которую вы настроили в консоли API - извлекает любые данные Google Analytics, которые вам нужны - отображает эти данные с помощью Google Charts API и все это делает в очень простой для изменения форме, Вы можете увидеть больше здесь: https://www.nuget.org/packages/GoogleAnalytics.GoogleCharts.NET/.

Надеюсь, Google когда-нибудь предоставит соответствующую документацию. Здесь я перечисляю все шаги для интеграции проверки подлинности на стороне сервера Google Analytics в ASP.NET C#.

Шаг 1. Создайте проект в консоли Google

Перейдите по ссылке https://console.developers.google.com/iam-admin/projects и создайте проект, нажав кнопку "Создать проект", введите имя проекта во всплывающем окне и отправьте его.

Шаг 2. Создание учетных данных и учетной записи службы

После создания проекта вы будете перенаправлены на страницу "API Manager". Нажмите на учетные данные и нажмите кнопку "Создать учетные данные". выберите "ключ учетной записи службы" из выпадающего списка, вы будете перенаправлены на следующую страницу. В раскрывающемся списке служебной учетной записи выберите "Новая учетная запись службы". Введите имя учетной записи службы и загрузите ключ p12. У него будет расширение p12. вы получите всплывающее окно с паролем "notasecret", которое установлено по умолчанию, и ваш личный ключ будет загружен.

Шаг 3: Создайте 0auth ID клиента

нажмите на раскрывающееся меню "создать учетные данные" и выберите "0auth ID клиента", вы будете перенаправлены на вкладку "Экран согласия 0auth". укажите случайное имя в текстовом поле имени проекта. выберите тип приложения как "Веб-приложение" и нажмите кнопку "Создать". Скопируйте сгенерированный идентификатор клиента в блокноте.

Шаг 4. Включите API

С левой стороны нажмите на вкладку "Обзор" и выберите "Включенные API" на горизонтальной вкладке. В строке поиска введите "Google Analytics API", щелкните раскрывающийся список и нажмите кнопку "Включить". Теперь снова найдите "Analytics Reporting V4" и включите его.

Шаг 5: Установите пакеты nuget

В Visual Studio выберите Инструменты> Диспетчер пакетов Nuget> Консоль диспетчера пакетов. Скопируйте и вставьте приведенный ниже код в консоль, чтобы установить пакеты nuget.

Установить-пакет Google.Apis.Analytics.v3

Пакет установки DotNetOpenAuth.Core -Version 4.3.4.13329

Вышеуказанные два пакета - это аналитические пакеты Google и пакеты ноджетов DotNetOpenAuth.

Шаг 6. Предоставьте разрешение "Просмотр и анализ" учетной записи службы

Перейдите в учетную запись Google Analytics, нажмите вкладку "Администратор" и выберите "Управление пользователями" в левом меню, выберите домен, к которому вы хотите получить доступ к данным аналитики, вставьте в него идентификатор электронной почты учетной записи службы и выберите разрешение "Чтение и анализ". из выпадающего списка. Идентификатор электронной почты учетной записи службы выглядит следующим образом: googleanalytics@googleanalytics.iam.gserviceaccount.com.

Рабочий код

КОД ПЕРЕДНЕГО КОНЦА:

Скопируйте и вставьте приведенный ниже скрипт встраивания аналитики в свой интерфейс, иначе вы также можете получить этот код на странице документации по Google Analytics.

 <script>
    (function (w, d, s, g, js, fs) {
        g = w.gapi || (w.gapi = {}); g.analytics = { q: [], ready: function (f) { this.q.push(f); } };
        js = d.createElement(s); fs = d.getElementsByTagName(s)[0];
        js.src = 'https://apis.google.com/js/platform.js';
        fs.parentNode.insertBefore(js, fs); js.onload = function () { g.load('analytics'); };
    }(window, document, 'script'));</script>

Вставьте приведенный ниже код в тег body главной страницы.

 <asp:HiddenField ID="accessToken" runat="server" />
<div id="chart-1-container" style="width:600px;border:1px solid #ccc;"></div>
        <script>
           var access_token = document.getElementById('<%= accessToken.ClientID%>').value;

            gapi.analytics.ready(function () {
                /**
                 * Authorize the user with an access token obtained server side.
                 */
                gapi.analytics.auth.authorize({
                    'serverAuth': {
                        'access_token': access_token
                    }
                });
                /**
                 * Creates a new DataChart instance showing sessions.
                 * It will be rendered inside an element with the id "chart-1-container".
                 */
                var dataChart1 = new gapi.analytics.googleCharts.DataChart({
                    query: {
                        'ids': 'ga:53861036', // VIEW ID <-- Goto your google analytics account and select the domain whose analytics data you want to display on your webpage. From the URL  ex: a507598w53044903p53861036. Copy the digits after "p". It is your view ID
                        'start-date': '2016-04-01',
                        'end-date': '2016-04-30',
                        'metrics': 'ga:sessions',
                        'dimensions': 'ga:date'
                    },
                    chart: {
                        'container': 'chart-1-container',
                        'type': 'LINE',
                        'options': {
                            'width': '100%'
                        }
                    }
                });
                dataChart1.execute();


                /**
                 * Creates a new DataChart instance showing top 5 most popular demos/tools
                 * amongst returning users only.
                 * It will be rendered inside an element with the id "chart-3-container".
                 */


            });
</script>

Вы также можете получить свой View ID от https://ga-dev-tools.appspot.com/account-explorer/

НАЗАД КОНЕЦ КОД:

 using System;
    using System.Linq;
    using System.Collections.Generic;
    using System.Collections.Specialized;
    using System.Web.Script.Serialization;
    using System.Net;
    using System.Text;
    using Google.Apis.Analytics.v3;
    using Google.Apis.Analytics.v3.Data;
    using Google.Apis.Services;
    using System.Security.Cryptography.X509Certificates;
    using Google.Apis.Auth.OAuth2;
    using Google.Apis.Util;
    using DotNetOpenAuth.OAuth2;
    using System.Security.Cryptography;

    namespace googleAnalytics
    {
        public partial class api : System.Web.UI.Page
        {
            public const string SCOPE_ANALYTICS_READONLY = "https://www.googleapis.com/auth/analytics.readonly";

            string ServiceAccountUser = "googleanalytics@googleanalytics.iam.gserviceaccount.com"; //service account email ID
            string keyFile = @"D:\key.p12"; //file link to downloaded key with p12 extension
            protected void Page_Load(object sender, EventArgs e)
            {

               string Token = Convert.ToString(GetAccessToken(ServiceAccountUser, keyFile, SCOPE_ANALYTICS_READONLY));

               accessToken.Value = Token;

                var certificate = new X509Certificate2(keyFile, "notasecret", X509KeyStorageFlags.Exportable);

                var credentials = new ServiceAccountCredential(

                    new ServiceAccountCredential.Initializer(ServiceAccountUser)
                    {
                        Scopes = new[] { AnalyticsService.Scope.AnalyticsReadonly }
                    }.FromCertificate(certificate));

                var service = new AnalyticsService(new BaseClientService.Initializer()
                {
                    HttpClientInitializer = credentials,
                    ApplicationName = "Google Analytics API"
                });

                string profileId = "ga:53861036";
                string startDate = "2016-04-01";
                string endDate = "2016-04-30";
                string metrics = "ga:sessions,ga:users,ga:pageviews,ga:bounceRate,ga:visits";

                DataResource.GaResource.GetRequest request = service.Data.Ga.Get(profileId, startDate, endDate, metrics);


                GaData data = request.Execute();
                List<string> ColumnName = new List<string>();
                foreach (var h in data.ColumnHeaders)
                {
                    ColumnName.Add(h.Name);
                }


                List<double> values = new List<double>();
                foreach (var row in data.Rows)
                {
                    foreach (var item in row)
                    {
                        values.Add(Convert.ToDouble(item));
                    }

                }
                values[3] = Math.Truncate(100 * values[3]) / 100;

                txtSession.Text = values[0].ToString();
                txtUsers.Text = values[1].ToString();
                txtPageViews.Text = values[2].ToString();
                txtBounceRate.Text = values[3].ToString();
                txtVisits.Text = values[4].ToString();

            }


         public static dynamic GetAccessToken(string clientIdEMail, string keyFilePath, string scope)
        {
            // certificate
            var certificate = new X509Certificate2(keyFilePath, "notasecret");

            // header
            var header = new { typ = "JWT", alg = "RS256" };

            // claimset
            var times = GetExpiryAndIssueDate();
            var claimset = new
            {
                iss = clientIdEMail,
                scope = scope,
                aud = "https://accounts.google.com/o/oauth2/token",
                iat = times[0],
                exp = times[1],
            };

            JavaScriptSerializer ser = new JavaScriptSerializer();

            // encoded header
            var headerSerialized = ser.Serialize(header);
            var headerBytes = Encoding.UTF8.GetBytes(headerSerialized);
            var headerEncoded = Convert.ToBase64String(headerBytes);

            // encoded claimset
            var claimsetSerialized = ser.Serialize(claimset);
            var claimsetBytes = Encoding.UTF8.GetBytes(claimsetSerialized);
            var claimsetEncoded = Convert.ToBase64String(claimsetBytes);

            // input
            var input = headerEncoded + "." + claimsetEncoded;
            var inputBytes = Encoding.UTF8.GetBytes(input);

            // signature
            var rsa = certificate.PrivateKey as RSACryptoServiceProvider;
            var cspParam = new CspParameters
            {
                KeyContainerName = rsa.CspKeyContainerInfo.KeyContainerName,
                KeyNumber = rsa.CspKeyContainerInfo.KeyNumber == KeyNumber.Exchange ? 1 : 2
            };
            var aescsp = new RSACryptoServiceProvider(cspParam) { PersistKeyInCsp = false };
            var signatureBytes = aescsp.SignData(inputBytes, "SHA256");
            var signatureEncoded = Convert.ToBase64String(signatureBytes);

            // jwt
            var jwt = headerEncoded + "." + claimsetEncoded + "." + signatureEncoded;

            var client = new WebClient();
            client.Encoding = Encoding.UTF8;
            var uri = "https://accounts.google.com/o/oauth2/token";
            var content = new NameValueCollection();

            content["assertion"] = jwt;
            content["grant_type"] = "urn:ietf:params:oauth:grant-type:jwt-bearer";

            string response = Encoding.UTF8.GetString(client.UploadValues(uri, "POST", content));


            var result = ser.Deserialize<dynamic>(response);

            object pulledObject = null;

            string token = "access_token";
            if (result.ContainsKey(token))
            {
                pulledObject = result[token];
            }


            //return result;
            return pulledObject;
        }

        private static int[] GetExpiryAndIssueDate()
        {
            var utc0 = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
            var issueTime = DateTime.UtcNow;

            var iat = (int)issueTime.Subtract(utc0).TotalSeconds;
            var exp = (int)issueTime.AddMinutes(55).Subtract(utc0).TotalSeconds;

            return new[] { iat, exp };
        }

        }
    }

Другой рабочий подход

Добавьте ниже код в ConfigAuth

  var googleApiOptions = new GoogleOAuth2AuthenticationOptions()
        {
            AccessType = "offline", // can use only if require
            ClientId = ClientId,
            ClientSecret = ClientSecret,
            Provider = new GoogleOAuth2AuthenticationProvider()
            {
                OnAuthenticated = context =>
                {
                    context.Identity.AddClaim(new Claim("Google_AccessToken", context.AccessToken));

                    if (context.RefreshToken != null)
                    {
                        context.Identity.AddClaim(new Claim("GoogleRefreshToken", context.RefreshToken));
                    }
                    context.Identity.AddClaim(new Claim("GoogleUserId", context.Id));
                    context.Identity.AddClaim(new Claim("GoogleTokenIssuedAt", DateTime.Now.ToBinary().ToString()));
                    var expiresInSec = 10000;
                    context.Identity.AddClaim(new Claim("GoogleTokenExpiresIn", expiresInSec.ToString()));


                    return Task.FromResult(0);
                }
            },

            SignInAsAuthenticationType = DefaultAuthenticationTypes.ApplicationCookie
        };
        googleApiOptions.Scope.Add("openid"); // Need to add for google+ 
        googleApiOptions.Scope.Add("profile");// Need to add for google+ 
        googleApiOptions.Scope.Add("email");// Need to add for google+ 
        googleApiOptions.Scope.Add("https://www.googleapis.com/auth/analytics.readonly");

        app.UseGoogleAuthentication(googleApiOptions);

Добавьте ниже код, пространства имен и относительные ссылки

 using Google.Apis.Analytics.v3;
 using Google.Apis.Analytics.v3.Data;
 using Google.Apis.Auth.OAuth2;
 using Google.Apis.Auth.OAuth2.Flows;
 using Google.Apis.Auth.OAuth2.Responses;
 using Google.Apis.Services;
 using Microsoft.AspNet.Identity;
 using Microsoft.Owin.Security;
 using System;
 using System.Threading.Tasks;
 using System.Web;
 using System.Web.Mvc;

public class HomeController : Controller
{
    AnalyticsService service;
    public IAuthenticationManager AuthenticationManager
    {
        get
        {
            return HttpContext.GetOwinContext().Authentication;
        }
    }

    public async Task<ActionResult> AccountList()
    {
        service = new AnalyticsService(new BaseClientService.Initializer()
        {
            HttpClientInitializer = await GetCredentialForApiAsync(),
            ApplicationName = "Analytics API sample",
        });


        //Account List
        ManagementResource.AccountsResource.ListRequest AccountListRequest = service.Management.Accounts.List();
        //service.QuotaUser = "MyApplicationProductKey";
        Accounts AccountList = AccountListRequest.Execute();



        return View();
    }

    private async Task<UserCredential> GetCredentialForApiAsync()
    {
        var initializer = new GoogleAuthorizationCodeFlow.Initializer
        {
            ClientSecrets = new ClientSecrets
            {
                ClientId = ClientId,
                ClientSecret = ClientSecret,
            },
            Scopes = new[] { "https://www.googleapis.com/auth/analytics.readonly" }
        };
        var flow = new GoogleAuthorizationCodeFlow(initializer);

        var identity = await AuthenticationManager.GetExternalIdentityAsync(DefaultAuthenticationTypes.ApplicationCookie);
        if (identity == null)
        {
            Redirect("/Account/Login");
        }

        var userId = identity.FindFirstValue("GoogleUserId");

        var token = new TokenResponse()
        {
            AccessToken = identity.FindFirstValue("Google_AccessToken"),
            RefreshToken = identity.FindFirstValue("GoogleRefreshToken"),
            Issued = DateTime.FromBinary(long.Parse(identity.FindFirstValue("GoogleTokenIssuedAt"))),
            ExpiresInSeconds = long.Parse(identity.FindFirstValue("GoogleTokenExpiresIn")),
        };

        return new UserCredential(flow, userId, token);
    }
}

Добавьте это в Application_Start() в Global.asax

  AntiForgeryConfig.UniqueClaimTypeIdentifier = ClaimTypes.NameIdentifier;
Другие вопросы по тегам