Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ionic-framework/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# Google Analytics API-在服务器端以编程方式获取页面视图_C#_Silverlight 4.0_Google Analytics_Server Side_Visitor Statistic - Fatal编程技术网

C# Google Analytics API-在服务器端以编程方式获取页面视图

C# Google Analytics API-在服务器端以编程方式获取页面视图,c#,silverlight-4.0,google-analytics,server-side,visitor-statistic,C#,Silverlight 4.0,Google Analytics,Server Side,Visitor Statistic,我们有一个由多个页面组成的web应用程序。我们在Google Analytics上注册了我们的web应用程序域,页面浏览量跟踪工作如预期(在Analytics面板中,我们可以看到每个页面的页面浏览量)。现在,我们希望此页面视图信息存储在数据库的后端。因此,我们希望创建一个每天运行一次的后端流程,并从AnalyticsAPI获取页面视图 这当然需要在代码中完成。从最初的研究看来,为了访问分析API,必须进行身份验证过程,这意味着人类用户必须输入id和密码 问题是,只能用代码完成吗?在日期参数中写前

我们有一个由多个页面组成的web应用程序。我们在Google Analytics上注册了我们的web应用程序域,页面浏览量跟踪工作如预期(在Analytics面板中,我们可以看到每个页面的页面浏览量)。现在,我们希望此页面视图信息存储在数据库的后端。因此,我们希望创建一个每天运行一次的后端流程,并从AnalyticsAPI获取页面视图

这当然需要在代码中完成。从最初的研究看来,为了访问分析API,必须进行身份验证过程,这意味着人类用户必须输入id和密码


问题是,只能用代码完成吗?

在日期参数中写前导0很重要。2011-07-01可以工作,但2011-07-1不能。不使用前导0将导致400个错误请求。@Thijs是的,我为此绞尽脑汁。我正在使用这段代码,并将endDate设置为DateTime.Now。但突然有一天它停止了工作。我花了几个小时才弄明白。使用DateTime.Now.ToString(“yyyy-MM-dd”);解决了这个问题。如何获得单个页面或与表达式匹配的所有页面的页面视图?我可以从localhost使用此代码,但当我从生产环境运行它时(在我可以访问的许多专用服务器上尝试过,但肯定没有超过每日配额),我在生产中收到了403禁止信息,其代码与生产中的代码完全相同。有人知道为什么会这样吗?应该是什么来源?
    //-------------- 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();
    }