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