Google Analytics API - программно извлекать виды страниц на стороне сервера

StackOverflow https://stackoverflow.com/questions/6806577

Вопрос

У нас есть веб -приложение, которое состоит из нескольких страниц. Мы зарегистрировали наш домен веб -приложения для Google Analytics и просмотров страниц, как и ожидалось (на панели аналитики мы можем увидеть представления страниц для каждой страницы). Теперь мы хотим, чтобы эта страница просмотрела информацию, которая хранилась в задней части нашего БД. Таким образом, мы хотим создать контрольный процесс, который будет работать один раз каждый день, и извлекать представления страниц из Analytics API.

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

Вопрос в том, можно ли это сделать только с кодом?

Это было полезно?

Решение

    //-------------- Get Auth Token -------------------

    WebClient webClient = new WebClient();
    NameValueCollection data = new NameValueCollection();
    data.Add("accountType", "GOOGLE");
    data.Add("Email", "xxxx@gmail.com");
    data.Add("Passwd", "xxxx");//Passwd, not a misspell.
    data.Add("service", "analytics");
    data.Add("source", "xxxx-xxxx-xx");//Could be anything.

    byte[] bytes = webClient.UploadValues("https://www.google.com/accounts/ClientLogin", "POST", data);
    string tokens = Encoding.UTF8.GetString(bytes);
    string authToken = extractAuthToken(tokens);

    //-------------- Get page views -------------------

    string feed = "https://www.google.com/analytics/feeds/data";

    //Required:
    string ids = "ga:xxxx";
    string metrics = "ga:pageviews";
    string startDate = "2011-06-25";
    string endDate = "2011-07-25";

    //Optional:
    string dimensions = "ga:pagePath";
    string sort = "-ga:pageviews";            

    string feedUrl = string.Format("{0}?ids={1}&dimensions={2}&metrics={3}&sort={4}&start-date={5}&end-date={6}",
        feed, ids, dimensions, metrics, sort, startDate, endDate);

    webClient.Headers.Add("Authorization", "GoogleLogin " + authToken);
    string result = webClient.DownloadString(feedUrl);

    //-------------- Extract data from xml -------------------

    XDocument xml = XDocument.Parse(result);
    var ns1 = "{http://www.w3.org/2005/Atom}";
    var ns2 = "{http://schemas.google.com/analytics/2009}";

    var q = from entry in xml.Descendants()
            where entry.Name == ns1 + "entry"
            select new
            {
                PagePath = entry.Element(ns2 + "dimension").Attribute("value").Value,
                Views = entry.Element(ns2 + "metric").Attribute("value").Value
            };

    //-------------- Do something with data -------------------
    foreach (var page in q)
    {
        Debug.WriteLine(page.PagePath + " " + page.Views);                
    }

    //-------------- Help Method -------------------
    private string extractAuthToken(string data)
    {          
        var tokens = data.Split(new string[] { "\n" }, StringSplitOptions.RemoveEmptyEntries);            
        return tokens.Where(token => token.StartsWith("Auth=")).Single();
    }
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top